京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

Oracle中的instr()函数 详解及应用

2019-3-26 16:36| 发布者: zhaojun917| 查看: 1385| 评论: 0|原作者: 梦想之都-俊月星空

摘要: oracle 函数gd_getkeyvalue 实现截取源字符串sourcestrin中keystartin到keyendin中间的字符串例:select gd_getkeyvalue('key1=val1;key2=val2;','key1=',';') from dual;返回值为 val1drop function gd_getkeyvalue ...

oracle 函数gd_getkeyvalue 实现截取源字符串sourcestrin中keystartin到keyendin中间的字符串

例: select gd_getkeyvalue('key1=val1;key2=val2;','key1=',';') from  dual;
返回值为  val1

drop function gd_getkeyvalue;

create or replace function gd_getkeyvalue( sourcestrin  in varchar2 ,keystartin  in varchar2,keyendin  in varchar2)

return  varchar2

is

 ret_cattype varchar2(1000);

 tmp_str varchar2(4000);

 

begin

ret_cattype :='';

tmp_str:='';

 

select substr(sourcestrin, instr(sourcestrin,keystartin)+length(keystartin),length(sourcestrin)-length(keystartin)) into tmp_str from dual;

dbms_output.put_line(tmp_str);

select substr(tmp_str,0,instr(tmp_str,keyendin)-1) into ret_cattype from dual;


   return(ret_cattype);

end gd_getkeyvalue;


1、instr()函数的格式  (俗称:字符查找函数)

格式一:instr( string1, string2 )    /   instr(源字符串, 目标字符串)

格式二:instr( string1, string2 [, start_position [, nth_appearance ] ] )   /   instr(源字符串, 目标字符串, 起始位置, 匹配序号)

解析:string2 的值要在string1中查找,是从start_position给出的数值(即:位置)开始在string1检索,检索第nth_appearance(几)次出现string2。

  注:在Oracle/PLSQL中,instr函数返回要截取的字符串在源字符串中的位置。只检索一次,也就是说从字符的开始到字符的结尾就结束。

2、实例

格式一

1 select instr('helloworld','l') from dual; --返回结果:3    默认第一次出现“l”的位置
2 select instr('helloworld','lo') from dual; --返回结果:4    即:在“lo”中,“l”开始出现的位置
3 select instr('helloworld','wo') from dual; --返回结果:6    即“w”开始出现的位置

格式二

复制代码
1 select instr('helloworld','l',2,2) from dual;  --返回结果:4    也就是说:在"helloworld"的第2(e)号位置开始,查找第二次出现的“l”的位置
2 select instr('helloworld','l',3,2) from dual;  --返回结果:4    也就是说:在"helloworld"的第3(l)号位置开始,查找第二次出现的“l”的位置
3 select instr('helloworld','l',4,2) from dual;  --返回结果:9    也就是说:在"helloworld"的第4(l)号位置开始,查找第二次出现的“l”的位置
4 select instr('helloworld','l',-1,1) from dual;  --返回结果:9    也就是说:在"helloworld"的倒数第1(d)号位置开始,往回查找第一次出现的“l”的位置
5 select instr('helloworld','l',-2,2) from dual;  --返回结果:4    也就是说:在"helloworld"的倒数第1(d)号位置开始,往回查找第二次出现的“l”的位置
6 select instr('helloworld','l',2,3) from dual;  --返回结果:9    也就是说:在"helloworld"的第2(e)号位置开始,查找第三次出现的“l”的位置
7 select instr('helloworld','l',-2,3) from dual; --返回结果:3    也就是说:在"helloworld"的倒数第2(l)号位置开始,往回查找第三次出现的“l”的位置
复制代码

 

注:MySQL中的模糊查询 like 和 Oracle中的 instr() 函数有同样的查询效果; 如下所示:

MySQL: select * from tableName where name like '%helloworld%';
Oracleselect * from tableName where instr(name,'helloworld')>0;  --这两条语句的效果是一样的

 

 

 

 

关闭

站长推荐上一条 /6 下一条

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2025-7-1 22:24 , Processed in 0.036571 second(s), 19 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2025 Discuz! Team.

返回顶部