MySQL replace通配符替换

MySQL replace通配符替换,第1张

mssql的replace支持通配符,而mysql想要实现该功能,还需费一翻手脚。

请看:

SELECT CONCAT('<A href="',

SUBSTRING_INDEX(

SUBSTRING_INDEX('xyz<A href="/v3/uploadfile/UploadFiles_5625/201107/2011070122330714.jpg" target=_blank>mmm </A>xyzxyz<A href="/v3/uploadfile/UploadFiles_5625/201107/2011070122330713.jpg" target=_blank></A>xyzxyz<A href="/v3/uploadfile/UploadFiles_5625/201107/2011070122330715.jpg" target=_blank>xxx </A>xyz'

,'<A href="',-3)

,'"',1)

,'" target=_blank></A>')

这句代码中出现SUBSTRING_INDEX,其函数原型为SUBSTRING_INDEX(str,delim,num),其返回在str中第num个delim之前或之后的字符串,若num为正则为向后取,为负则为向后取。

如SUBSTRING_INDEX(‘abcdefg’,'d',1)返回字符串efg,SUBSTRING_INDEX(‘abcdefg’,'d',-1)返回abc。

开头所示代码则表示,在字符串中寻找第3个'<A href="'之后的字符,而后取该返回字符串第一个'"'之前的字符串,则最后返回/v3/uploadfile/UploadFiles_5625/201107/2011070122330715.jpg。

本次所想替换的是文本代码中无效的链接代码,寻到不同后,再用concat连接起来,update即可。如例:

UPDATE phpcms_c_tougao

SET content=REPLACE(content,CONCAT('<A href="', SUBSTRING_INDEX( SUBSTRING_INDEX(content,'<A href="',-1) ,'"',1) ,'" target=_blank></A>'),'')

WHERE 1

(完毕)

set

simtime=replace(time,'-','')即可

mysql的内置函数都是全局函数,没有对象的概念

,所以不能使用set

simtime=time.replace('-','')类似的语法。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/7433259.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-05
下一篇 2023-04-05

发表评论

登录后才能评论

评论列表(0条)

保存