mysql中替换字符串(正则) 模糊

首先描述一下,我遇到的问题:
以下是数据库中的一个表mt2:
+----+------------------------------------------+
| id | name |
+----+------------------------------------------+
| 1 | sdfsfbeijingsldjfsld |
| 2 | sdfsfshanghaisldjfsld |
| 3 | sdfsfjnsldjfsld |
| 4 | sdfsfqdsldjfsld |
+----+------------------------------------------+
遇到的要求是:将该表中的内容删除。
众所周知,replace函数是不支持正则表达式的,所以只能采用其他的方法处理。
于是,我是使用了下面的sql语句:

update mt2 set name = replace(name, substring(name, locate('', name),locate('', name)-locate(''+10, name)),'');

问题解决了。
结果:
+----+-------------------+
| id | name |
+----+-------------------+
| 1 | sdfsfactsldjfsld |
| 2 | sdfsfactsldjfsld |
| 3 | sdfsfactsldjfsld |
| 4 | sdfsfactsldjfsld |
+----+-------------------+

下面描述下,所用到的函数:
locate:

LOCATE(substr,str)
POSITION(substr IN str)
返回子串 substr 在字符串 str 中第一次出现的位置。如果子串 substr 在 str 中不存在,返回值为 0:

substring

SUBSTR(str,pos,len): 由中的第位置开始,选出接下去的个字元。

replace

replace(str1, str2, str3): 在字串 str1 中,當 str2 出現時,將其以 str3 替代。

你可能感兴趣的:(babyjoycry)