mysql替换字符串 批量替换sql语句
发布:smiling 来源: PHP粉丝网 添加日期:2014-09-24 16:16:37 浏览: 评论:0
在mysql字符替换我们常用用update更新语句与replace替换函数进行操作,我们可以利用where来限制是替换指定内容还是替换所有内容,下面一起来看看相关教程.
replace替换:mysql中replace函数直接替换mysql数据库中某字段中的特定字符串,不再需要自己写函数去替换,用起来非常的方便,mysql 替换函数replace().
replace:replace(str1, str2, str3),例子代码如下:
UPDATE `table_name` SET `field_name` = replace (`field_name`,'from_str','to_str') WHERE `field_name` LIKE '%from_str%'
说明:
table_name —— 表的名字
field_name —— 字段名
from_str —— 需要替换的字符串
to_str —— 替换成的字符串
例如,mysql替换表的字段里面内容,代码如下:
- mysql> select id,type from items limit 10;
- +--------+--------+
- | id | type |
- +--------+--------+
- | 0001 | 780000 |
- | 0002 | 780000 |
- | 0003 | 780000 |
- | 0004 | 780000 |
- | 0005 | 780000 |
- | 150419 | 780000 |
- | 150420 | 780000 |
- | 150421 | 780000 |
- | 150422 | 780000 |
- | 150423 | 780000 |
- +--------+--------+
把type字段中的“78”改成“79” 用replace函数,sql如下:
- mysql> update items set type=replace(type,'79','78');
- Query OK, 17536 rows affected (0.72 sec)
- Rows matched: 17536 Changed: 17536 Warnings: 0
再查询,代码如下:
- mysql> select id,type from items limit 10;
- +--------+--------+
- | id | type | www.phpfensi.com
- +--------+--------+
- | 0001 | 790000 |
- | 0002 | 790000 |
- | 0003 | 790000 |
- | 0004 | 790000 |
- | 0005 | 790000 |
- | 150419 | 790000 |
- | 150420 | 790000 |
- | 150421 | 790000 |
- | 150422 | 790000 |
- | 150423 | 790000 |
- +--------+--------+
- 10 rows in set (0.00 sec)
由查询结果到,数据已经更新成功.
正则替换 locate:
LOCATE(substr,str)
POSITION(substr IN str)
返回子串 substr 在字符串 str 中第一次出现的位置,如果子串 substr 在 str 中不存在,返回值为 0:
substring
SUBSTR(str,pos,len): 由<str>中的第<pos>位置开始,选出接下去的<len>个字元.
首先描述一下,我遇到的问题,以下是数据库中的一个表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 |
- +----+-------------------+
Tags: mysql替换字符串 mysql批量替换
相关文章
- ·mysql replace函数替换字符串(2014-10-09)
- ·mysql中replace替换字符串返回结果空或0(2015-04-20)
- ·mysql中UPDATE批量替换语句(2014-09-24)
- ·mysql批量查找和替换sql语句(2014-10-09)
- ·mysql字符串批量查找和替换(2014-10-10)
- ·mysql 中replace()批量替换指定字符语句(2014-10-15)
- ·mysql replace()批量替换指定字符实现语句(2014-10-15)
- ·MySQL批量替换单字段数据(2014-10-17)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)