构造q命令以获取所有表的元数据

时间:2015-04-27 20:39:22

标签: kdb

我想构建一个查询来检索每个表的表元数据。

我可以使用meta函数获取单个表的元数据。我可以使用tables \`.链接它,它返回.命名空间中的所有表,以构造(meta')tables `.

这几乎是我想要的,因为它返回元数据表的列表。问题是我不知道哪个元数据表属于哪个kdb表。

理想情况下,我可以构造一个返回表的查询,其中每一行都是tablename + meta tablename的结果。有关构建此类查询的建议吗?

1 个答案:

答案 0 :(得分:3)

q)trade:([] sym: 10?`4; time:10?.z.t; prx:10?100f; sz:10?10000);
q)quote:([] sym: 10?`4; time:10?.z.t; bPrx:10?100f; aPrx:10?100f; bSz:10?10000; aSz:10?10000);
q)testTable:update `s#a from ([] a:til 10; b: 10?`3; c:10?.z.p);
q)raze {update table:x from 0!meta x}'[tables[]]
    c    t f a table
    --------------------
    sym  s     quote
    time t     quote
    bPrx f     quote
    aPrx f     quote
    bSz  j     quote
    aSz  j     quote
    a    j   s testTable
    b    s     testTable
    c    p     testTable
    sym  s     trade
    time t     trade
    prx  f     trade
    sz   j     trade
  

我可以构造一个返回表的查询,其中每一行都是tablename +“meta tablename”的结果。有关构建此类查询的建议吗?

如果您确实想以这种方式进行,有很多方法。一个例子:

q)update tableMeta:meta'[table] from ([] table:tables[])
    table     tableMeta
    --------------------------------------------------------------------------------
    quote     (+(,`c)!,`sym`time`bPrx`aPrx`bSz`aSz)!+`t`f`a!("stffjj";``````;``````)
    testTable (+(,`c)!,`a`b`c)!+`t`f`a!("jsp";```;`s``)
    trade     (+(,`c)!,`sym`time`prx`sz)!+`t`f`a!("stfj";````;````)