substring(int beginIndex, int endIndex) 返回一个新字符串,它是此字符串的一个子字符串。该子字符串从指定的 beginIndex 处开始,一直到索引 endIndex - 1 处的字符。因此,该子字符串的长度为 endIndex-beginIndex。 "hamburger".substring(4, 8) returns "urge" InStrB 函数以及 InStr函数 返回一个字符串( String)在另一个字符串中首次出现的 字节位置。第一个字符被编为1 号。 INSTRB 该函数与INSTR的功能极为类似,也将反馈其中的一个字符串(参数)是否在另一个字符串(也是参数)当中。只是该函数返回的是一字节索引位置,而不是一字符索引位置。 数据库字符串函数 substr,substrb均为字符串截取函数,都带有三个参数,第一个参数为所要截取的字符串,第二个参数为strart(索引均从1开始),第三个参数为length。 SQL> select substr('今天是个好日子',3,5) from dual; ---------- 是个好日子 SQL> select substrb('今天是个好日子',3,5) from dual; ----- 天是 结论是substr是按照字来算的,而substrb()是按照字节来算的。看下面的例子: SQL> select substr('abcdef',3,4) from dual; cdef SQL> select substrb('abcdef',3,4) from dual; cdef 分析:对于字母来说,substr与substrb作用时一样的,但对于汉字来说,substr是按字来取值,而substrb是按字节来取值,当所取长度为奇数时,则自动舍弃最后一位字节。 |