关于Oracle里面的一些小函数
要求 A 数据库表中的一个字符串 可能含有 + 例 ORC+
也可能不含 +
B 要求如果该字符串含有 + 则取 + 之前的字符 例 ORC+ 取ORC
C 如果该字符串不含 + 则直接取该字符串
解答 利用ORACLE中 INSTR SUBSTR以及CASE WHEN语法即可实现
Oracle中函数
INSTR INSTR方法的格式为
INSTR(源字符串 目标字符串 起始位置 匹配序号)
默认查找顺序为从左到右 当起始位置为负数的时候 从右边开始查找
例 Select INSTR( ORC+ + ) From dual
返回的是"4" 如果该字符串没有匹配字符 返回的是 0
SUBSTR 取子字符串 取子字符串
SUBSTR(源字符串 起始位置 要取多少位)
从 起始位置 开始 取 多少"个
例 Select SUBSTR( ORC+ ) From dual
返回的是 ORC
全例如下
表T_RCV_ISSUE
WH_CD字段
取 WH_CD 如果该字段包含 + 取 + 之前的字符
如果该字段没有 + 取整个字段
T_RCV_ISSUE表
WH_CD 分别为 MR PS+ MR WS MR WS+ MR PS
执行
SELECT CASE
WHEN INSTR(WH_CD + ) >
THEN SUBSTR(WH_CD INSTR(WH_CD + ) )
ELSE WH_CD
END AS WH_CD
FROM T_RCV_ISSUE
lishixinzhi/Article/program/Oracle/201311/17245如果Oracle版本不是太低的话,使用 正则表达式函数 REGEXP_SUBSTR 处理。\x0d\x0a\x0d\x0a5个参数\x0d\x0a第一个是输入的字符串\x0d\x0a第二个是正则表达式\x0d\x0a第三个是标识从第几个字符开始正则表达式匹配。(默认为1)\x0d\x0a第四个是标识第几个匹配组。(默认为1)\x0d\x0a第五个是是取值范围:\x0d\x0ai:大小写不敏感;\x0d\x0ac:大小写敏感;\x0d\x0an:点号 . 不匹配换行符号;\x0d\x0am:多行模式;\x0d\x0ax:扩展模式,忽略正则表达式中的空白字符。\x0d\x0a\x0d\x0aSQL>SELECT\x0d\x0a 2REGEXP_SUBSTR(a,'[0-9]+')\x0d\x0a 3 FROM\x0d\x0a 4test_reg_substr\x0d\x0a 5 WHERE\x0d\x0a 6REGEXP_LIKE(a, '[0-9]+')
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)