with as 搭配 hint materialize的使用

今天看《SQL核心优化思想》第九章 生产中实际的优化案例时候

发现几处子查询优化时候,用到了搭配 hint materialize 的with as用法。

实际的案例是在一个IN的子查询的SQL中,子查询中返回数据量较小,但是主表中数据量很大

之前在表连接中学习到,两表进行NL嵌套循环,应让小表作为驱动表,大表作为被驱动表,同时在大表的连接列建立索引。

那针对此案例,应该将子查询作为NL的驱动表,这时应该利用with as,将子查询写入。

但是如果如果主表子表连接列没有索引,with as又没有hint materialize,优化器就不会自动将with as作为嵌套循环的驱动表。

 

那么此时就要引入/*+ materialize */的用法了。那么他和普通的with as又有什么区别呢?

首先大家应该都是到with as的用法吧,可以将复杂的SQL简化,优化整体的可读性。例如同时多段SQL中的相同部分,用with as代替,就变得很规整,可读性很高,也可粗略的理解为一个临时表。

我们经常利用GTT(GLOBAL TEMPORARY)全局临时表、MATERIALIZE VIEW物化视图来提高查询的效率,

那么此时添加HINT /*+ materialize */ 就可以粗略的看做成GTT,但是需要注意的是,with as与/*+ materialize */联合使用时,应注意此如果结果记录集比较庞大,还是推荐使用GTT,因为那里面可以指定索引等.

 

所以当大家实际使用with as的时候,如果发现并没有起到临时表的作用,可以尝试添加此hint。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值