oracle为什么要用函数,为什么说oracle在查询时,字段上使用函数会影响性能?还用那样的函数会影响性能?其他的数据也是一样吗?...

为什么说oracle在查询时,字段上使用函数会影响性能?还用那样的函数会影响性能?其他的数据也是一样吗?

mip版  关注:236  答案:5  悬赏:30

解决时间 2021-01-24 14:37

0f297412ac5f514bbb23ad3ec11db157.png

已解决

2021-01-23 16:39

这方面我的只是比较欠缺,请推荐本书,可以了解到诸如此类问题的程度,谢谢。

为什么有些函数就不会影响呢?比如说:to_date(),或to_char()之类的,好像是。不要较真函数名,意会,意会。 还有就是学习数据库的好书,也推荐下呗

最佳答案

8c6aa2fce5a32659b1ba4d74848841e2.png

2021-01-23 17:08

字段上使用函数会影响性能:

这个是要有以下前提:

1. 数据量很大。

2. 这个字段上面有索引。

例如有一个 ABC 表 ( id INT, myKeyWord varchar2(20), 其他很多字段......)

有1百万行记录。

其中 id 是主键,myKeyWord 上面有一个唯一索引。

当你执行

SELECt * FROM ABC WHERe myKeyWord = 'Oracle';

这个查询,将根据索引中的,快速的知道 'Oracle' 这个数据,在当前表里面有没有

如果有,在什么位置。

然后根据 位置 读取文件 (如果缓存里面已经有的,就不读取磁盘了),然后返回。

但是当你对字段加了一个函数以后,情况就发生变化了。

因为索引可能变成 不可用了。

例如

SELECt * FROM ABC WHERe TRANSLATE( myKeyWord, '123', '一二三') = 'Oracle一二三';

这种情况下,数据库只好把这100行的数据,每一行的 myKeyWord 都提取出来,

去执行一次 TRANSLATE( myKeyWord, '123', '一二三') 函数。

然后再拿执行后的结果,去和 'Oracle一二三' 作比较。

全部回答

34b16839fb07f051bab1bdb5f3934f98.png

1楼

2021-01-23 20:51

你指的应该是条件使用 函数吧,字段上用函数还好,如果不是复制计算的.

我用的是SQLSERVER 不过应该差不多

你条件使用函数时,即时条件有索引,也不会用到,因为要通过函数计算才得到一个值

所以一开始优化器根本无法用到索引直接定位到索引页

书。。oracle不清楚。。

这类问题属于性能调优。。oracle书很多应该很容易找得到

d5b476a24185cfa357a8519a3e5263b9.png

2楼

2021-01-23 19:54

orale 里的函数是需要进行解析的。你可以看oracle 的执行计划,

比如oracle 中 in 就没有 exists 快。 还有你用 like 的话也会慢的。

74c610e59e73621aa3a7300b4d81643a.png

3楼

2021-01-23 18:51

这个问题比较好解释,比如原来一个字符的字段你在上面建了一个索引,此时你在使用的时候在这个字段上加了一个to_number, 那么会发生类型转换,此时oracle一般情况下不会选择原有的索引,即使选择也不会有好的效果。解决方法,对于要使用转换函数的列建“函数索引”,并打开查询重写!

476afb57cde8ead1f7a18a4055c7091e.png

4楼

2021-01-23 18:38

是因为你是在列上建立的简单index,而不是函数index,因此在使用函数时,不会走你做的index,从而导致sql的性能降低

我要举报

如果感觉以上信息为低俗/不良/侵权的信息,可以点下面链接进行举报,我们会做出相应处理,感谢你的支持!

点此我要举报以上信息!

推荐资讯

大家都在看

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值