xueweizhang
e0cd8599d2
[fix](delete) fix delete from bug which can get wrong result (#17146)
理论上,如果是两次独立的删除,比如delete from table where a=1; delete from table where a=2;其实这个地方应该可以使用的,但是目前的代码,是把所有不同版本的delete predicates和不同列的delete predicates都放到一起了,失去了版本信息、失去了谓词间可能是and的关系,统一弱化成了delete predicates都是独立的,有一个delete predicates满足条件,就把page都去掉。
这个pr的修改方式,就是在当前代码的基础上,当只有一个delete predicate的时候才能保证后续淘汰page的正确性,所以这里一律加了 == 1的判断才传递delete predicates。
如果要把不同版本的delete predicates和不同列的delete predicates作为完整和严谨的逻辑去判断page,需要修改的设计就有点多了,目前的方案算是一种优先解决bug的思路,后续可以进一步把delete predicates这块加速zone判断进行page淘汰的逻辑完善,提高delete predicates使用的场景。
2023-02-28 09:20:10 +08:00
..
2022-10-25 16:37:07 +08:00
2023-02-09 15:51:32 +08:00
2023-02-28 09:20:10 +08:00
2023-02-27 14:23:28 +08:00
2023-02-20 10:00:25 +08:00
2023-02-21 17:53:19 +08:00
2022-08-15 23:12:07 +08:00
2022-07-29 10:45:36 +08:00
2023-02-28 09:20:10 +08:00