Maison >développement back-end >tutoriel php >这个如果用mysql语句来替换,请问要怎么写 ?
我的问题:
求一个网址截取的正则替换表达式
http://p.yiqifa.com/n?k=2mLErnws6E4H2mLErI6H2mLsWN3OrnDsWN2e6QLs1NDF6ZLErZyH2mLe6n6w3E3LMZqt6cuLUJeH&spm=1.1.1.1&t=http://www.xuansou.com/
这样一个网址,想把第二个http://前面的内容全部替换成空
也就是只想保留http://www.xuansou.com/
需要怎么弄,谢谢,我是菜鸟
jordan102版主的正确回答我已经结帖了:
$s = 'http://p.yiqifa.com/n?k=2mLErnws6E4H2mLErI6H2mLsWN3OrnDsWN2e6QLs1NDF6ZLErZyH2mLe6n6w3E3LMZqt6cuLUJeH&spm=1.1.1.1&t=http://www.xuansou.com/';
echo preg_replace('/.+?t=/', '', $s);
以上是用于php代码的,
这个如果用mysql语句来替换,请问要怎么写 ?
截取出来就是了
SUBSTRING_INDEX(字段名, 't=', -1)
update alibaba_site set url = replace(url,SUBSTRING_INDEX(url,'t=',-1),'') where id=2452
这样的话整个字段的值全部玩完了
update alibaba_site set url = replace(url,SUBSTRING_INDEX(url,'t=',-1),'') where id=2452
这样的话整个字段的值全部玩完了
update ylmf_site set url = SUBSTRING_INDEX(url,'url=',-1) where id=2452
试了这样是可以的,不过有个问题
就是最后一个网址的前面那些字符串是变化多端的
每替换一批都要修改一次
'前面那些字符串' 是指哪些?
这个最好用php处理,mysql不支持复杂的正则写法,如果觉得存储在字段的值,不满足自己,可以php写个正则替换脚本执行。
'前面那些字符串' 是指哪些?
怕种mysql正则好实现不,如果不好实现,用您的那个xxxx_index也是可以的,虽然麻烦了一点
update ylmf_site set url = concat('http', SUBSTRING_INDEX(url,'=http',-1)) where id=2452