当前位置: 首页 > news >正文

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),不过,一般我们也都用字节定义。

 

转载于:https://www.cnblogs.com/yuanchaoyong/p/7230583.html

相关文章:

  • SAS笔记(5) FLAG和计数器
  • 用于检测移动设备(包括平板电脑)的轻量级PHP类
  • 170511、Spring IOC和AOP 原理彻底搞懂
  • CodeChef Forest Gathering —— 二分
  • ReactiveSwift源码解析(九) SignalProducerProtocol延展中的Start、Lift系列方法的代码实现...
  • 在List中删除符合条件的内容
  • 亿级SQL Server运维的最佳实践PPT分享
  • socket简单理解
  • JAVA最佳实践
  • 关于Hibernate中get和load的区别
  • bootstrap-table 怎么自定义搜索按钮实现点击按钮进行查询
  • 新产品为了效果,做的比較炫,用了非常多的图片和JS,所曾经端的性能是非常大的问题,分篇记录前端性能优化的一些小经验。...
  • 百度地图坐标拾取
  • @RequestMapping-占位符映射
  • 夺命雷公狗TP3.2.3商城13-----无限极分类添加
  • 分享的文章《人生如棋》
  • 30天自制操作系统-2
  • canvas 绘制双线技巧
  • HTTP中GET与POST的区别 99%的错误认识
  • Java 网络编程(2):UDP 的使用
  • JavaScript 事件——“事件类型”中“HTML5事件”的注意要点
  • Java面向对象及其三大特征
  • MySQL QA
  • Nacos系列:Nacos的Java SDK使用
  • STAR法则
  • vue:响应原理
  • WinRAR存在严重的安全漏洞影响5亿用户
  • Xmanager 远程桌面 CentOS 7
  • 高度不固定时垂直居中
  • 你不可错过的前端面试题(一)
  • 人脸识别最新开发经验demo
  • 软件开发学习的5大技巧,你知道吗?
  • LevelDB 入门 —— 全面了解 LevelDB 的功能特性
  • 翻译 | The Principles of OOD 面向对象设计原则
  • ​ 无限可能性的探索:Amazon Lightsail轻量应用服务器引领数字化时代创新发展
  • #HarmonyOS:软件安装window和mac预览Hello World
  • (3)(3.5) 遥测无线电区域条例
  • (C语言)球球大作战
  • (HAL库版)freeRTOS移植STMF103
  • (poj1.2.1)1970(筛选法模拟)
  • (博弈 sg入门)kiki's game -- hdu -- 2147
  • (附源码)ssm高校社团管理系统 毕业设计 234162
  • (论文阅读26/100)Weakly-supervised learning with convolutional neural networks
  • (欧拉)openEuler系统添加网卡文件配置流程、(欧拉)openEuler系统手动配置ipv6地址流程、(欧拉)openEuler系统网络管理说明
  • (亲测)设​置​m​y​e​c​l​i​p​s​e​打​开​默​认​工​作​空​间...
  • (三)centos7案例实战—vmware虚拟机硬盘挂载与卸载
  • (五)Python 垃圾回收机制
  • (轉貼) UML中文FAQ (OO) (UML)
  • .NET单元测试
  • .net和php怎么连接,php和apache之间如何连接
  • .Net中的设计模式——Factory Method模式
  • [ABC294Ex] K-Coloring
  • [Angular] 笔记 6:ngStyle
  • [CareerCup] 6.1 Find Heavy Bottle 寻找重瓶子
  • [Firefly-Linux] RK3568修改控制台DEBUG为普通串口UART