我记得我曾在开发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⑻编码,汉字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),不过,一般我们也都用字节定义。
总结
本篇文章到此结束,如果您有相关技术方面疑问可以联系我们技术人员远程解决,感谢大家支持本站!
本文来源:https://www.yuntue.com/post/150512.html | 云服务器网,转载请注明出处!

微信扫一扫打赏
支付宝扫一扫打赏