mysql 正则表达式替换内容

遇到的问题: 
以下是数据库中的一个表mt2:

 代码如下 复制代码
+----+------------------------------------------+ 
| id | name                                     | 
+----+------------------------------------------+ 
|  1 | sdfsf<contact>beijing</contact>sldjfsld  | 
|  2 | sdfsf<contact>shanghai</contact>sldjfsld | 
|  3 | sdfsf<contact>jn</contact>sldjfsld       | 
|  4 | sdfsf<contact>qd</contact>sldjfsld       | 
+----+------------------------------------------+ 

遇到的要求是:将该表中<contact>到</contact>的内容删除。 
众所周知,replace函数是不支持正则表达式的,所以只能采用其他的方法处理。 
于是,我是使用了下面的sql语句:

 代码如下 复制代码

update mt2 set name = replace(name, substring(name, locate('<contact>', name),locate('</contact>', name)-locate('<contact>'+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): 由<str>中的第<pos>位置开始,选出接下去的<len>个字元。

replace

replace(str1, str2, str3): 在字串 str1 中,? str2 出??r,?⑵湟 str3 替代。

缺点:只能唯一出现一次<contact>到</contact>,出现多次只能多分成多次替换了

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
MySQL正则表达式是一种用于匹配和操作字符串的强大工具。它可以在MySQL数据库中进行模式匹配、搜索、替换等操作。在MySQL中,我们可以使用正则表达式来查找符合特定模式的数据。 以下是一些常用的MySQL正则表达式操作: 1. REGEXP:该操作符可用于在查询中使用正则表达式进行模式匹配。例如,可以使用`SELECT * FROM table_name WHERE column_name REGEXP 'pattern'`来查找符合特定模式的数据。 2. REGEXP_LIKE:该函数用于检查一个字符串是否与给定的正则表达式相匹配。例如,可以使用`SELECT * FROM table_name WHERE REGEXP_LIKE(column_name, 'pattern')`来查找符合特定模式的数据。 3. REGEXP_REPLACE:该函数用于将匹配到的字符串替换为新的字符串。例如,可以使用`SELECT REGEXP_REPLACE(column_name, 'pattern', 'replacement') FROM table_name`来替换符合特定模式的字符串。 4. REGEXP_INSTR:该函数用于返回一个字符串中第一个匹配项的位置。例如,可以使用`SELECT REGEXP_INSTR(column_name, 'pattern') FROM table_name`来获取符合特定模式的字符串的位置。 5. REGEXP_SUBSTR:该函数用于提取符合特定模式的子字符串。例如,可以使用`SELECT REGEXP_SUBSTR(column_name, 'pattern') FROM table_name`来提取符合特定模式的子字符串。 请注意,MySQL正则表达式的语法可以使用标准的正则表达式语法,但也有一些特定的规则和限制。在使用正则表达式时,建议参考MySQL官方文档以了解更多详细信息和示例。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值