mysql部分替换sql语句分享

有时候需要对mysql中的内容进行部分替换,那么可以参考下面的文章。

将cdb_pms表subject字段中的Welcom to替换成 欢迎光临
代码如下:
UPDATE `cdb_pms`
SET `subject` = REPLACE(`subject`, ‘Welcome to’, ‘欢迎光临’)
WHERE INSTR(`subject`,’Welcome to’) > 0

替换cdb_posts表的message字段,将“viewthread.php?tid=3989”替换成“viewthread.php?tid=16546”
代码如下:
UPDATE `cdb_posts`
SET `message`= REPLACE(`message`, ‘viewthread.php?tid=3989’, ‘viewthread.php?tid=16546’)
WHERE INSTR(`message`,’viewthread.php?tid=3989′) > 0 ;

删除所有的空格
代码如下:
UPDATE `es_product` SET `pro_pub_time` = TRIM(`pro_pub_time`)

删除所有饱含'[‘或者’]’或者’.’的字符
代码如下:
UPDATE `es_product` SET `pro_pub_time` = REPLACE(`pro_pub_time`, ‘[‘,”) WHERE INSTR(`pro_pub_time`,'[‘) > 0
UPDATE `es_product` SET `pro_pub_time` = REPLACE(`pro_pub_time`, ‘]’,”) WHERE INSTR(`pro_pub_time`,’]’) > 0
UPDATE `es_product` SET `pro_pub_time` = REPLACE(`pro_pub_time`, ‘.’,’-‘) WHERE INSTR(`pro_pub_time`,’.’) > 0

替换所有含中文’-‘的为英文’-‘
代码如下:
UPDATE `es_product` SET `pro_pub_time` = REPLACE(`pro_pub_time`, ‘-’,’-‘) WHERE INSTR(`pro_pub_time`,’-’) > 0

将所有的年月都替换成’-‘
代码如下:
UPDATE `es_product` SET `pro_pub_time` = REPLACE(`pro_pub_time`, ‘年’,’-‘) WHERE INSTR(`pro_pub_time`,’年’) > 0
UPDATE `es_product` SET `pro_pub_time` = REPLACE(`pro_pub_time`, ‘月’,’-‘) WHERE INSTR(`pro_pub_time`,’月’) > 0

将所有’2005-04-‘这种类型的替换成’2005-04-01’
代码如下:
UPDATE `es_product` SET `pro_pub_time` = CONCAT( `pro_pub_time`, ’01’) WHERE SUBSTRING_INDEX( `pro_pub_time`, ‘-‘, -1) = ” AND LENGTH(`pro_pub_time`) > 0 AND LENGTH(`pro_pub_time`) > 5

将所有’2005-‘这种类型替换成’2005-01-01’
代码如下:
UPDATE `es_product` SET `pro_pub_time` = CONCAT( `pro_pub_time`, ’01-01′) WHERE INSTR(`pro_pub_time`,’-‘) > 0 AND LENGTH(`pro_pub_time`) = 5

将所有 饱含’-‘,但是位数小于8的改成追加’-01′
代码如下:
UPDATE `es_product` SET `pro_pub_time` = CONCAT( `pro_pub_time`, ‘-01′) WHERE INSTR(`pro_pub_time`,’-‘) > 0 AND LENGTH(`pro_pub_time`)
将所有’2005’这样的改成’2005-01-01′
代码如下:
UPDATE `es_product` SET `pro_pub_time` = CONCAT(`pro_pub_time`,’-01-01′) WHERE INSTR(`pro_pub_time`,’-‘) = 0 AND LENGTH(`pro_pub_time`) = 4

最后将所有’2005-01-01’格式化成’2005年01月’
代码如下:
UPDATE `es_product` SET `pro_pub_time` = DATE_FORMAT(`pro_pub_time`,’%Y年%m月’) WHERE INSTR(`pro_pub_time`,’-‘) > 0

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/435934.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 16:09:52
下一篇 2025年11月7日 16:14:59

相关推荐

发表回复

登录后才能评论
关注微信