mysql数据库中如何进行模糊替换字符串
比如我有一个表叫goods有一个列叫goods_namegoods_name有的值是'xxx(ooo)'我现在要做的是只要是这个字段的值带括号就把括号里的值替换成公斤'x...
比如我有一个表叫goods 有一个列叫goods_name
goods_name有的值是'xxx(ooo)' 我现在要做的是只要是这个字段的值带括号 就把括号里的值替换成公斤
'xxx(ooo)'就替换成'xxx(公斤)'
'aaa(bbb)'就替换成'aaa(公斤)'
'ccc'就不用进行操作 因为'ccc'里没有括号
怎么写sql? 展开
goods_name有的值是'xxx(ooo)' 我现在要做的是只要是这个字段的值带括号 就把括号里的值替换成公斤
'xxx(ooo)'就替换成'xxx(公斤)'
'aaa(bbb)'就替换成'aaa(公斤)'
'ccc'就不用进行操作 因为'ccc'里没有括号
怎么写sql? 展开
2个回答
展开全部
您好,update mt2 set name = replace(name, substring(name, locate('<contact>', name),locate('</contact>', name)-locate('<contact>'+10, name)),'');
locate:
LOCATE(substr,str)
POSITION(substr IN str)
返回子串 substr 在字符串 str 中第一次出现的位置。如果子串 substr 在 str 中不存在,返回值为 0:
substring
SUBSTR(str,pos,len): 由<str>中的第<pos>位置开始,选出接下去的<len>个字元。
replace
replace(str1, str2, str3): 在字串 str1 中,当 str2 出现时,将其以 str3 替代。
locate:
LOCATE(substr,str)
POSITION(substr IN str)
返回子串 substr 在字符串 str 中第一次出现的位置。如果子串 substr 在 str 中不存在,返回值为 0:
substring
SUBSTR(str,pos,len): 由<str>中的第<pos>位置开始,选出接下去的<len>个字元。
replace
replace(str1, str2, str3): 在字串 str1 中,当 str2 出现时,将其以 str3 替代。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询