substr(oracle) vs substring(mssql) Out了吧?
本文讨论的是MSSQL和ORACLE的字符截取函数,substring和substr,的一点差异。下面是验证经过:
Oracle:
select substr('123456',0,3) result from dual
union all
select substr('123456',1,3) result from dual
union all
select substr('123456',2,3) result from dual
union all
select substr('123456',3,3) result from dual
union all
select substr('123456',-3,3) result from dual
结果:
RESULT
123
123
234
345
456
MSSQL:
select substring('123456',0,3) as result
union all
select substring('123456',1,3) as result
union all
select substring('123456',2,3) as result
union all
select substring('123456',3,3) as result
union all
select substring('123456',-3,3) as result
结果集:
result
12
123
234
345
(空)
结论:起始位置都是从1开始,但是oracle有容错,如果从0开始返回结果是从1开始的。oracle更强可以支持倒数截取字符。
ps:为啥研究这个,因为同事抱怨oracle的substr不是从1开始,跟MSSQL的不同,看吧结论出来了。
作者:数据酷软件
出处:https://www.cnblogs.com/datacool/archive/2013/04/16/sql_substr2substring_desc.html
关于作者:20年编程从业经验,持续关注MES/ERP/POS/WMS/工业自动化
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明。
联系方式: qq:71008973;wx:6857740733
基于人脸识别的考勤系统 地址: https://gitee.com/afeng124/viewface_attendance_ext
自己开发安卓应用框架 地址: https://gitee.com/afeng124/android-app-frame
WPOS(warehouse+pos) 后台演示地址: http://47.239.106.75:8080/