oracle string从0还是1开始
SQL code
select length('sdf')from dual --3
SELECT substr('sdf',0,1) FROM dual --s //从第0位开始,取1个字符,就 取s
SELECT substr('sdf',1,1) FROM dual --s //从第1位开始,取1个字符,还是s ??这是为什么
oracle里计算字符串是从第1 位开始还是从第0位也可以
------解决方案--------------------当然是从1开始.
------解决方案--------------------从1开始,自己测一下就行了:
SQL code
SQL> select substr('abcdef', 1, 2) from dual;
SU
--
ab
------解决方案--------------------
1
------解决方案--------------------
------解决方案--------------------
呵呵,其实从负数位开始取也可以;
可以做如下验证:
SQL> select substr('abcdefgkopi',1,3) from dual;
SUB
---
abc
SQL> select substr('abcdefgkopi',0,3) from dual;
SUB
---
abc
SQL> select substr('abcdefgkopi',-3,2) from dual;
SU
--
op
SQL> select substr('abcdefgkopi',-3,5) from dual;
SUB
---
opi