度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 1006|回复: 1
打印 上一主题 下一主题

[分享] oracle中length、lengthb、substr、substrb用法小结

[复制链接]

348

主题

3572

帖子

9325

积分

论坛元老

Rank: 8Rank: 8

积分
9325
跳转到指定楼层
楼主
发表于 2020-5-8 23:38:03 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

我记得我曾经在开发form的时候犯过这样一个错误,对于form中的某个字段,对应于数据库中某张表的字段,假设在数据库中这个字段一般也就用到20个汉字的长度,后来我在开发form的时候,设置item类型长度的时候,我惯性的设置成了50byte,想着就算是20个汉字,最多也就占40个byte长度嘛。可是,就因为这一个想当然,结果出现错误了,后来发现数据库字符集编码是utf8,那么应该设置为60。从那以后,每次涉及到给字段设置长度的时候,我都会特别注意下,到底是啥编码。

在oracle中,比较常见的可能是length、substr,至少我看到的大部分都是这两个,要不是昨天看代码发现了lengthb、substrb,估计我也遗忘了。length表示的是字符串的字符长度,lengthb表示的是字符串的字节长度;substr表示根据字符长度获取子串,substrb表示根据字节长度来获取字串。下面直接看例子来说明:

  1. SELECT length('叶德华abc') -- length按字符计,汉字、英文、数字都是1个字符,故这里返回6
  2.   FROM dual;
  3. SELECT lengthb('叶德华abc') -- length按字节计,我这里是UTF-8编码,汉字3个字节,英文一个字节,故这里返回12
  4.   FROM dual;
  5. SELECT substr('叶德华abc', -- substr按字符截取,截取到a,返回:叶德华a
  6.               1,
  7.               4)
  8.   FROM dual;
  9. SELECT substrb('叶德华abc',
  10.                1,
  11.                2) -- substrb按字节截取,2不足一个汉字长度,返回:两个空格
  12.   FROM dual;
  13. SELECT substrb('叶德华abc',
  14.                1,
  15.                3) -- substrb按字节截取,3刚好是一个汉字长度,返回:叶
  16.   FROM dual;
  17. SELECT substrb('叶德华abc',
  18.                1,
  19.                4) -- substrb按字节截取,4多余一个汉字少于两个汉字,返回:叶 加一个空格
  20.   FROM dual;
复制代码

在oracle中应该还有其他类似的方法,这里就不总结了,大概就是这么个意思。补充一下,据说在oracle中定义字符类型的时候默认的长度是byte,比如varchar2(20)表示的是20个字节长度,如果要定义成字符,则varchar2(20 char),不过,一般我们也都用字节定义。


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
沙发
发表于 2020-5-9 13:42:07 | 只看该作者
学习了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2024-11-23 22:37 , Processed in 0.135456 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表