我是靠谱客的博主 爱听歌汉堡,最近开发中收集的这篇文章主要介绍Oracle的hint的作用,Oracle Hint 用法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

正确的语法是:

select /*+ index(x idx_t) */ * from t x where x.object_id=123

/*+    */ 和注释很像,比注释多了一个“+”,这就是Hint

上面这个hint的意思是让Oracle执行这个SQL时强制走索引。

如果hint的语法有错误,Oracle是不会报错,只是把/* */里的内容当做注释而已。

不合理使用Hint的危害:

由于表中的数据是会变化,一般不能在程序中的sql里用Hint,假如像上面的Hint一样强制走索引。万一某一天object_id=123的返回结果占了全表的50%以上,这时候走索引会比全表扫描慢。所以不该强制所有情况都走索引。Hint一般用于一次执行,比如做数据抽取。而且一般Oracle在99%的情况下会判断正确是否该走索引,不需要我们去指定。Hint只是为了应付1%的情况下。

Append的使用:

append是另一种Hint,一般用法:

insert /*+ append */ into b select * from a;

这种insert比普通的insert会快一些,但代价也大。

1、当表中的数据被delete以后,表空间会留下空隙,下次insert时会去填补空隙。但是append的insert不会去找空隙,而且直接追加到新的空间里。如果一直用append,会使表空间越来越大。

2、这点是比较致命的,就是用append的时候,会把整个表锁住,别的用户即使insert别的数据也要被阻塞。

所以生产环境肯定不能用append,append也一般用于数据抽取一类的工作。

其实大多数情况下,用append提高不了多少效率。

因为append之所以快的原因,是因为减少了日志产生。

只有以下场景append会减少日志产生:

1、非归档模式下

2、归档模式下,表的状态是nologging

首先非归档状态一般是不可能的,稍微重要点的系统都必须开归档。

归档模式下nologging一般也很少,没日志了,也就意味着将来恢复数据会不完整,这是有风险的。

总之就是,Hint适用的场景其实很少,就是知道有这么个东西,用的时候要谨慎

参考:

https://www.cnblogs.com/attlia/p/3866593.html

Oracle Hint 用法

标签:nologging   比较   sql   状态   注释   恢复   dex   内容   复数

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:https://www.cnblogs.com/xiaohuizhenyoucai/p/11002242.html

最后

以上就是爱听歌汉堡为你收集整理的Oracle的hint的作用,Oracle Hint 用法的全部内容,希望文章能够帮你解决Oracle的hint的作用,Oracle Hint 用法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(41)

评论列表共有 0 条评论

立即
投稿
返回
顶部