oracle instr mysql_MySql中代替Oracle的instr方法 | 学步园

-- Function "INSTR2" DDL

CREATE FUNCTION `INSTR2`(v_string varchar(5000), v_delimiter varchar(20), pos int,nth int) RETURNS varchar(5000)

begin

declare icount int default 0;

declare len int default 0;

declare len1 int default 0;

declare lth int default 0;

declare lth1 int default 0;

declare str1 varchar(5000) default '';

set len = length(v_string);

set len1 = length(v_delimiter);

set lth = instr(v_string ,v_delimiter);

if lth=0 then

set icount = lth;

else

if pos is null then

set icount = lth;

elseif pos < 0 then

set icount = locate(v_delimiter,v_string,len+pos-1);

elseif pos = 0 then

set icount = 0;

elseif pos = 1 then

if nth is null then

set icount = lth;

elseif nth >=1 then

set icount = if (length(substring_index(v_string ,v_delimiter,nth))=0 or length(substring_index(v_string,v_delimiter ,nth))=length(v_string ),0,length(substring_index(v_string ,v_delimiter,nth))+1);

else

set icount = 0;

end if;

else

if (nth is null) or (nth=1) then

set icount = locate(v_delimiter,v_string,pos);

elseif nth > 1 then

set str1 = substring(v_string,pos) ;

set icount = if (length(substring_index(str1 ,v_delimiter,nth))=0 or length(substring_index(str1,v_delimiter ,nth))=length(str1),0,length(substring_index(str1 ,v_delimiter,nth)));

if icount<>0 then

set icount = icount+pos;

end if;

end if;

end if;

end if;

return icount;

end;

转自:http://pangxin630.blog.163.com/blog/static/2630889420092443218927/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值