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会优先转换数值范例到字符范例. (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |