文章导航绿软下载站软件下载安卓资源苹果资源专题

您当前所在位置:首页数据库Oracle → Oracle字符串截取

Oracle字符串截取

时间:2015/6/28来源:IT猫扑网作者:网管联盟我要评论(0)

  关于Oracle里面的一些小函数

  要求:A.数据库表中的一个字符串  可能含有"+" 例:ORC+001

  也可能不含"+"

  B.要求如果该字符串含有"+",则取"+"之前的字符 例:ORC+001 取ORC

  C.如果该字符串不含"+",则直接取该字符串。

  解答:利用ORACLE中 INSTR,SUBSTR以及CASE WHEN语法即可实现。

  Oracle中函数

  INSTR:INSTR方法的格式为

  INSTR(源字符串, 目标字符串, 起始位置, 匹配序号)

  默认查找顺序为从左到右。当起始位置为负数的时候,从右边开始查找。

  例:Select INSTR('ORC+001','+',1,1) From dual

  返回的是"4" 如果该字符串没有匹配字符 返回的是"0"。

  SUBSTR:取子字符串 取子字符串

  SUBSTR(源字符串,起始位置,要取多少位)

  从"起始位置"开始,取"多少"个

  例 Select SUBSTR('ORC+001',1,3) From dual;

  返回的是"ORC"

  全例如下:

  表T_RCV_ISSUE

  WH_CD字段

  取 WH_CD 如果该字段包含"+",取"+"之前的字符

  如果该字段没有"+",取整个字段

  T_RCV_ISSUE表

  WH_CD 分别为 MR-PS+007,MR-WS,MR-WS+001,MR-PS

  执行

  SELECT CASE

  WHEN INSTR(WH_CD, '+', 1, 1) > 0

  THEN SUBSTR(WH_CD, 1, INSTR(WH_CD, '+', 1, 1) - 1)

  ELSE WH_CD

  END AS WH_CD

  FROM   T_RCV_ISSUE

  结果:MR-PS,MR-WS,MR-WS,MR-PS

关键词标签:Oracle字符串截取

相关阅读 没有数据

文章评论
发表评论

热门文章 使用低权限Oracle数据库账户得到管理员权限使用低权限Oracle数据库账户得到管理员权限Windows平台上Oracle数据库服务解析Windows平台上Oracle数据库服务解析Oracle数据库优化之数据库磁盘I/OOracle数据库优化之数据库磁盘I/O详解Oracle数据库中文全文索引详解Oracle数据库中文全文索引

相关软件

人气排行 ORACLE SQL 判断字符串是否为数字的语句Oracle中使用alter table来增加,删除,修改列的语法ORACLE和SQL语法区别归纳(1)oracle grant 授权语句如何加速Oracle大批量数据处理Oracle删除表的几种方法ORACLE修改IP地址后如何能够使用Oracle 10g创建表空间和用户并指定权限