加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长百科 > 正文

oracle避免改变索引列的类型

发布时间:2021-01-18 06:02:00 所属栏目:站长百科 来源:网络整理
导读:当较量差异数据范例的数据时,ORACLE自动对罗列办简朴的范例转换. 假设 EMPNO是一个数值范例的索引列. SELECT … FROM EMP WHERE EMPNO = ‘123’ 现实上,颠末ORACLE范例转换,语句转化为: SELECT … FROM EMP WHERE EMPNO = TO_NUMBER(‘123’) 荣幸的是,范例

当较量差异数据范例的数据时,ORACLE自动对罗列办简朴的范例转换.

假设 EMPNO是一个数值范例的索引列.

SELECT …

FROM EMP

WHERE EMPNO = ‘123’

现实上,颠末ORACLE范例转换,语句转化为:

SELECT …

FROM EMP

WHERE EMPNO = TO_NUMBER(‘123’)

荣幸的是,范例转换没有产生在索引列上,索引的用途没有被改变.

此刻,假设EMP_TYPE是一个字符范例的索引列.

SELECT …

FROM EMP

WHERE EMP_TYPE = 123

这个语句被ORACLE转换为:

SELECT …

FROM EMP

WHERE TO_NUMBER(EMP_TYPE)=123

由于内部产生的范例转换,这个索引将不会被用到!

?

为了停止ORACLE对你的SQL举办隐式的范例转换,最好把范例转换用显式示意出来. 留意当字符和数值较量时,ORACLE会优先转换数值范例到字符范例.

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读