后退 刷新 前进 收藏 顶部 |   知道 黑匣子 富媒体 技术服务

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

程序猿 SQL mysql 替换 字符串 正则 模糊... (shuke.2014-01-17 02:22)
MySQL正则表达式SQL
首先描述一下,我遇到的问题:
以下是数据库中的一个表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语句:
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 出現時,將其以 str3 替代。
2 楼 shuke[2014-01-20 16:54]
这个还没有测试过
进度:100% 返回程序猿

解决织梦图集中上传图片时跳出302错误

图片新热点

导航


目录


    站内搜索
    首页 | W3C | ME