- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章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表示根据字节长度来获取字串。下面直接看例子来说明:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
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函数用法介绍的全部内容,希望对大家有所帮助.
原文链接:http://blog.csdn.net/zhangbingtao2011/article/details/51384393 。
最后此篇关于oracle中length、lengthb、substr、substrb函数用法介绍的文章就讲到这里了,如果你想了解更多关于oracle中length、lengthb、substr、substrb函数用法介绍的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
**摘要:**下面就来给大家介绍这三个函数在字符截取时的一些用法与区别。 本文分享自华为云社区《GaussDB(DWS)中的字符截取三胞胎》,作者:我站在北方的天空下 。 在GaussDB(DWS)中
我正在从 oracle 数据库转换为 mysql 数据库。在 Oracle 数据库中,使用函数 substrb 返回字符串的一部分,从指定字节位置开始,指定长度的字节数。 示例 select subs
Oracle: select substrb('よろしくお愿いいたします',2,3) from dual;结果:ろ 如何转换成Postgresql? 最佳答案 对于 byte,在 postgresql
我是一名优秀的程序员,十分优秀!