mysql获取字符串位置然后替换_mysql中替换字符串(通过位置)

From:



首先描述一下,我遇到的问题:

以下是数据库中的一个表mt2:

+----+------------------------------------------+

| id | name                                     |

+----+------------------------------------------+

|  1 | sdfsfbeijingsldjfsld  |

|  2 | sdfsfshanghaisldjfsld |

|  3 | sdfsfjnsldjfsld       |

|  4 | sdfsfqdsldjfsld       |

+----+------------------------------------------+

遇到的要求是:将该表中到的内容删除。

众所周知,replace函数是不支持正则表达式的,所以只能采用其他的方法处理。

于是,我是使用了下面的sql语句:

Sql代码

193f5841003ecd593660d8425d36dea6.gif 

cea580622891f848d59b67cbb06c2825.png

5df27c24de249ef7f49c33d731c4535b.gif

updatemt2setname=replace(name,substring(name, locate('',name),locate('',name)-locate(''+10,name)),'');

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 替代。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值