暂无图片
openGauss使用的是哪个优化器,CBO or RBO? 有啥区别?
我来答
分享
暂无图片 匿名用户
openGauss使用的是哪个优化器,CBO or RBO? 有啥区别?

openGauss使用的是哪个优化器,CBO or RBO? 有啥区别?

我来答
添加附件
收藏
分享
问题补充
3条回答
默认
最新
吾喾

RBO(Rule-Based Optimization)#
RBO: Rule-Based Optimization也即“基于规则的优化器”,该优化器按照硬编码在数据库中的一系列规则来决定SQL的执行计划。
如在规则中:索引的优先级大于全表扫描。
在RBO中,有着一套严格的使用规则,只要你按照规则去写SQL语句,无论数据表中的内容怎样,也不会影响到你的“执行计划”,也就是说RBO对数据不“敏感”。这就要求开发人员非常了解RBO的各项细则,不熟悉规则的开发人员写出来的SQL性能可能非常差。
但在实际的过程中,数据的量级会严重影响同样SQL的性能,这也是RBO的缺陷所在。毕竟规则是死的,数据是变化的,所以RBO生成的执行计划往往是不可靠的,不是最优的。
CBO(Cost-Based Optimization)#
CBO: Cost-Based Optimization也即“基于代价的优化器”,该优化器通过根据优化规则对关系表达式进行转换,生成多个执行计划,然后CBO会通过根据统计信息(Statistics)和代价模型(Cost Model)计算各种可能“执行计划”的“代价”,即COST,从中选用COST最低的执行方案,作为实际运行方案。
CBO依赖数据库对象的统计信息,统计信息的准确与否会影响CBO做出最优的选择。
目前各大数据库和大数据计算引擎都倾向于使用CBO。

暂无图片 评论
暂无图片 有用 0
打赏 0
刘浩

openGauss优化器是典型的基于代价的优化 (Cost-Based Optimization,简称CBO)。在这种优化器模型下,数据库根据表的元组数、字段宽度、NULL记录比率、distinct值、MCV值、HB值等表的特征值,以及一定的代价计算模型,计算出每一个执行步骤的不同执行方式的输出元组数和执行代价(cost),进而选出整体执行代价最小/首元组返回代价最小的执行方式进行执行。

区别如下:

 RBO: Rule-Based Optimization 基于规则的优化器

CBO: Cost-Based Optimization 基于代价的优化器

暂无图片 评论
暂无图片 有用 0
打赏 0
酷哥

再补充一些:

RBO 应该已经废弃; 

CBO,主要由“查询转换、代价评估、执行计划生成”三部分组成,其依赖于统计信息(1.analyze收集;2.pg_statistic系统表存储有关该数据库中表和索引列的统计数据,需要有系统管理员权限)。

暂无图片 评论
暂无图片 有用 0
打赏 0
回答交流
Markdown


请输入正文
提交
相关推荐
opengauss可以在centos8.2安装吗?
回答 1
建议参考官方的要求:ARM:openEuler20.03LTS(推荐采用此操作系统)麒麟V10x86:openEuler20.03LTSCentOS7.6说明:当前安装包只能在英文操作系统上安装使用。
openGauss批量插入报错
回答 1
这是jdbc层的硬限制,参数不能过多,预防内存溢出
docker 装不上opengauss,pull了最新版的image之后,run命令创建container并不能正常启动
回答 6
我也有同样问题!!现在解决了嘛!我用dockerdesktop安装opengauss5.0.0版本时也遇到了同样的问题,请问你是否解决呢可以说一下解决办法嘛
openGauss数据库是open了华为哪个数据库,是GaussDB?
回答 3
openGauss就是openGauss呀,底层是postgresql
参数
回答 4
已采纳
第一个问题需要排查操作系统层环境变量的设置,或者是你的用户名“openGauss”,换个普通的名称“opengauss”试试。第二个加–passwordXXXX
openGauss的内存池是什么?
回答 2
当memorypoolenable默认设置为off时,主要是考虑到性能和复杂性之间的平衡。启用内存池虽然有诸多潜在优势,但也会引入额外的开销。在一些简单的应用场景或者对内存管理要求不高的情况下,不启用
求openGauss一个现成的软件架构示意图?
回答 1
openGauss主要包含了openGauss服务器,客户端驱动,OM等模块,penGauss软件的架构如下所示。在openGauss的文档中,将openGauss服务器称为实例。OM运维管理模块(O
opengauss是不能通过可视化界面建表嘛?
回答 1
datastudio确定可以可视化建表,你的问题可能不在工具上面
Mogdb/opengauss 分区表的一个分区 用什么方法能导出来
回答 6
学习
预安装openGauss报错GAUSS-52200: Unable to import module: libssl.so.1.1
回答 1
yuminstallylibaiodevel\flex\bison\ncursesdevel\glibcdevel\patch\lsbrelease检查rpm是否安装,以及所需的版本是否一致。LDLI