博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle截取字符串和查找字符串
阅读量:6245 次
发布时间:2019-06-22

本文共 1314 字,大约阅读时间需要 4 分钟。

oracle 截取字符(substr),检索字符位置(instr) case when then else end语句使用 收藏 

常用函数:substr和instr
1.SUBSTR(string,start_position,[length])    求子字符串,返回字符串
解释:string 元字符串
       start_position   开始位置(从0开始)
       length 可选项,子字符串的个数
For example:
substr("ABCDEFG", 0); //返回:ABCDEFG,截取所有字符 
substr("ABCDEFG", 2); //返回:CDEFG,截取从C开始之后所有字符 
substr("ABCDEFG", 0, 3); //返回:ABC,截取从A开始3个字符 
substr("ABCDEFG", 0, 100); //返回:ABCDEFG,100虽然超出预处理的字符串最长度,但不会影响返回结果,系统按预处理字符串最大数量返回。 
substr("ABCDEFG", -3); //返回:EFG,注意参数-3,为负值时表示从尾部开始算起,字符串排列位置不变。

2.INSTR(string,subString,position,ocurrence)查找字符串位置

解释:string:源字符串
      subString:要查找的子字符串
      position:查找的开始位置
      ocurrence:源字符串中第几次出现的子字符串
For example:
INSTR('CORPORATE FLOOR','OR', 3, 2)中,源字符串为'CORPORATE FLOOR', 目标字符串为'OR',起始位置为3,取第2个匹配项的位置;返回结果为 14 '

 

实战:节目单中记录包含哪一集,影响总体统计,故需要提取“你真漂亮”就好。

 你真漂亮(23)(高清)

 你真漂亮(22)(高清)
 你真漂亮(24)(高清)
 你真漂亮(25)(高清)
 你真漂亮(21)(高清) 

 

select trunc(a.watch_time) watch_time,

substr(a.program_name,0,instr(a.program_name,'(',1,1)-1),
sum(a.watch_duration) watch_duration from draw a
where a.program_name in (select distinct b.program_name from Korea_program b)
group by trunc(a.watch_time),substr(a.program_name,0,instr(a.program_name,'(',1,1)-1)
order by trunc(a.watch_time),substr(a.program_name,0,instr(a.program_name,'(',1,1)-1)

 

做个小推广:程序员经常久坐,颈椎毛病比较多,特别推荐

转载于:https://www.cnblogs.com/longzhongren/p/4313410.html

你可能感兴趣的文章
【MySQL (6) | 详细分析MySQL事务日志redo log】
查看>>
Linux远程管理常用命令
查看>>
魅族mx5详细打开usb调试模式的步骤
查看>>
ConstraintLayout的使用教程
查看>>
前后端俱全的 具有聊天功能的 react 项目
查看>>
Redux reselect
查看>>
Spring 通过xml获得容器的三种方法比较
查看>>
MySQL索引面试题
查看>>
Systemd 入门教程:命令篇
查看>>
JS 常用函数垫片
查看>>
快速批量检查所有虚拟机的各项指标
查看>>
【软件开发底层知识修炼】五 gcc-C语言编译器
查看>>
React组件生命周期
查看>>
RxJava2.0的初学者必备教程(三)
查看>>
Git代码托管,SSH不同环境办公
查看>>
老司机 iOS 周报 #58 | 2019-03-11
查看>>
Hystrix问题记录
查看>>
Linux 上ps 命令的使用
查看>>
祛斑用什么产品比较好?简单一步轻松搞定
查看>>
OkHttp发起请求源码阅读(一)
查看>>