• Oracle截取字符串和查找字符串


    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)

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

  • 相关阅读:
    BZOJ1040: [ZJOI2008]骑士
    酱油记:GDKOI2018
    BZOJ1800: [Ahoi2009]fly 飞行棋
    BZOJ3894: 文理分科
    树链剖分
    文件格式问题
    10.23模拟赛
    snakes
    数据结构题目
    jquery easyui datebox 的使用 .
  • 原文地址:https://www.cnblogs.com/longzhongren/p/4313410.html
Copyright © 2020-2023  润新知