OceanBase 数据库所支持的查询改写规则分为基于规则的查询改写和基于代价的查询改写。

    基于代价的查询改写并不能总是把 SQL 往“好”的方向进行改写,需要使用代价模型来判断。一个典型的基于代价的改写就是 Or-Expansion。

    这里需要注意的是,基于代价的改写之后可能又会重新触发基于规则的改写,所以整体上的基于代价的改写和基于规则的改写也会采用这种迭代的方式进行改写。