IT猫扑网:您身边最放心的安全下载站! 最新更新|软件分类|软件专题|手机版|论坛转贴|软件发布

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

Oracle字符串截取

时间:2015-06-28 00:00:00 来源: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中使用alter table来增加,删除,修改列的语法 Oracle中使用alter table来增加,删除,修改列的语法 oracle中使用SQL语句修改字段类型-oracle修改SQL语句案例 oracle中使用SQL语句修改字段类型-oracle修改SQL语句案例 误删Oracle数据库实例的控制文件 误删Oracle数据库实例的控制文件 为UNIX服务器设置Oracle全文检索 为UNIX服务器设置Oracle全文检索

相关下载

    人气排行 oracle中使用SQL语句修改字段类型-oracle修改SQL语句案例 Oracle中使用alter table来增加,删除,修改列的语法 ORACLE SQL 判断字符串是否为数字的语句 ORACLE和SQL语法区别归纳(1) oracle grant 授权语句 ORACLE修改IP地址后如何能够使用 如何加速Oracle大批量数据处理 Oracle删除表的几种方法