oracle中length、lengthb、substr、substrb函数用法介绍

所属分类: 数据库 / oracle 阅读数: 547
收藏 0 赞 0 分享

我记得我曾经在开发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函数用法介绍的全部内容,希望对大家有所帮助。感兴趣的朋友可以参阅:oracle求字符串长度函数length()和hengthb()简介  、 Oracle RMAN自动备份控制文件方法介绍  、 oracle 数据库启动阶段分析等。感谢大家对本站的支持。

  

更多精彩内容其他人还在看

修改oracle数据库用户名及密码的方法

有时候我们可能不知道一个用户的密码,但是又需要以这个用户做一些操作,又不能去修改掉这个用户的密码,这个时候,就可以利用一些小窍门,来完成操作
收藏 0 赞 0 分享

oracle ORA-00988 missing or invalid password 错误

在设置数据库实例的密码时,注意不要以数字开头,否则您将会遇到 ORA-00988 missing or invalid password (口令缺失或无效) 错误
收藏 0 赞 0 分享

oracle实现多行合并的方法

这篇文章主要介绍了oracle实现多行合并的方法,实例讲述了oracle10g以后提供的函数WMSYS.WM_CONCAT的使用技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

Oracle删除死锁进程的方法

这篇文章主要介绍了Oracle删除死锁进程的方法,涉及查找被锁表及删除对应进程的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

oracle数据库索引失效

这篇文章主要介绍了oracle数据库索引失效的原因及如何避免索引失效,有需要的小伙伴参考下。
收藏 0 赞 0 分享

Oracle通过时间(分钟)计算有几天几小时几分钟的方法

这篇文章主要介绍了Oracle通过时间(分钟)计算有几天几小时几分钟的方法,涉及Oracle时间操作的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

ORACLE中的日期加减操作实例介绍

这篇文章主要介绍了ORACLE中的日期加减操作实例介绍,本文讲解了对当前日期增加一个小时、对当前日期增加50分种、对当前日期增加45秒、对当前日期增加3天、对当前日期增加4个月等内容,需要的朋友可以参考下
收藏 0 赞 0 分享

Oracle中scott表结构与简单查询实例分析

这篇文章主要介绍了Oracle中scott表结构与简单查询,实例分析Oracle查询的相关技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

Oracle 11G密码180天过期后的修改方法

在Oracle 11G 创建用户时缺省密码过期限制是180天, 如果超过180天用户密码未做修改则该用户无法登录,下面与大家分享下修改方法
收藏 0 赞 0 分享

oracle 11g的警告日志和监听日志的删除方法

这篇文章主要介绍了oracle 11g的警告日志和监听日志的删除方法,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多