oracle中length、lengthb、substr、substrb函数⽤法介绍
我记得我曾经在开发form的时候犯过这样⼀个错误,对于form中的某个字段,对应于数据库中某张表的字段,假设在数据库中这个字段⼀般也就⽤到20个汉字的长度,后来我在开发form的时候,设置item类型长度的时候,我惯性的设置成了50byte,想着就算是20个汉字,最多也就占40个byte长度嘛。可是,就因为这⼀个想当然,结果出现错误了,后来发现数据库字符集编码是utf8,那么应该设置为60。从那以后,每次涉及到给字段设置长度的时候,我都会特别注意下,到底是啥编码。
在oracle中,⽐较常见的可能是length、substr,⾄少我看到的⼤部分都是这两个,要不是昨天看代码发现了lengthb、substrb,估计我也遗忘了。length表⽰的是字符串的字符长度,lengthb表⽰的是字符串的字节长度;substr表⽰根据字符长度获取⼦串,substrb表⽰根据字节长度来获取字串。下⾯直接看例⼦来说明:
SELECT length('叶德华abc') -- length按字符计,汉字、英⽂、数字都是1个字符,故这⾥返回6
FROM dual;
SELECT lengthb('叶德华abc') -- length按字节计,我这⾥是UTF-8编码,汉字3个字节,英⽂⼀个字节,故这⾥返回12
FROM dual;
SELECT substr('叶德华abc', -- substr按字符截取,截取到a,返回:叶德华a
1,
4)
FROM dual;
SELECT substrb('叶德华abc',
1,
2) -- substrb按字节截取,2不⾜⼀个汉字长度,返回:两个空格
FROM dual;
SELECT substrb('叶德华abc',
1,
3) -- substrb按字节截取,3刚好是⼀个汉字长度,返回:叶
FROM dual;
SELECT substrb('叶德华abc',
1,
4) -- substrb按字节截取,4多余⼀个汉字少于两个汉字,返回:叶加⼀个空格
FROM dual;
在oracle中应该还有其他类似的⽅法,这⾥就不总结了,⼤概就是这么个意思。补充⼀下,据说在oracle中定义字符类型的时候默认的长度是byte,⽐如varchar2(20)表⽰的是20个字节长度,如果要定义成字符,则varchar2(20 char),不过,⼀般我们也都⽤字节定义。
字符串长度怎么设置总结
以上就是本⽂关于oracle中length、lengthb、substr、substrb函数⽤法介绍的全部内容,希望对⼤家有所帮助。感兴趣的朋友可以参阅:、、等。感谢⼤家对本站的⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。