Q语言 - 维护功能(Maintenance Functions)
优质
小牛编辑
134浏览
2023-12-01
.Q.en
.Q.en是一个二元函数,它通过枚举符号列来帮助扩展表。 当我们处理历史数据库(splayed,分区表等)时,它尤其有用。 -
.Q.en[`:directory;table]
其中directory是sym file所在的历史数据库的主目录, table是要枚举的表。
手动枚举表不需要将它们保存为splayed表,因为这将通过 -
.Q.en[`:directory_where_symbol_file_stored]table_name
.Q.dpft
.Q.dpft函数有助于创建分区和分段表。 它是.Q.en高级形式,因为它不仅会.Q.en表,还会创建分区表。
.Q.dpft使用了四个参数 -
我们要创建分区的数据库的符号文件句柄,
q我们将用于对表进行分区的数据值,
将要应用parted(`p#)属性的字段的名称(通常是`sym),和
表名。
让我们举个例子看看它是如何工作的 -
q)tab:([]sym:5?`msft`hsbc`samsung`ibm;time:5?(09:30:30);price:5?30.25)
q).Q.dpft[`:c:/q/;2014.08.24;`sym;`tab]
`tab
q)delete tab from `
'type
q)delete tab from `/
'type
q)delete tab from .
'type
q)delete tab from `.
`.
q)tab
'tab
我们已从内存中删除了表格tab 。 现在让我们从db加载它
q)\l c:/q/2014.08.24/
q)\a
,`tab
q)tab
sym time price
-------------------------------
hsbc 07:38:13 15.64201
hsbc 07:21:05 5.387037
msft 06:16:58 11.88076
msft 08:09:26 12.30159
samsung 04:57:56 15.60838
.Q.chk
.Q.chk是一个monadic函数,其单个参数是根目录的符号文件句柄。 它通过检查根中的每个分区子目录,在必要时在分区中创建空表。
.Q.chk `:directory
其中directory是历史数据库的主目录。