3

我想从分区数据库表中删除一些行,但是这个查询不起作用:

delete from myPartTable where date=2013.05.30,col1<>"A"

我宁愿不将整个表加载到内存中,从 rdb 中删除,然后再写回磁盘。我可以直接从磁盘表中删除吗?

4

1 回答 1

3

kdb 本身并不提供操作分区表的简单方法。两种选择:

  1. 要减少内存使用,请获取要删除的行的索引。逐列遍历并删除。这是减少分区数据库操作的内存使用时的标准做法。

  2. 维护一个标记该行是否被删除的列,根据需要更新该布尔值以标记删除。这将以减慢每个必须过滤未删除位置的选择为代价提供更快的删除速度。稍后,实际删除行。

于 2013-06-17T13:09:17.973 回答