sql的update语句 批量更新某字段

数据库 专栏收录该内容
33 篇文章 0 订阅

Mysql 批量替换:

1 有时候要实现字段的批量替换

update 表名 set 字段A = replace(字段A ,"png","jpg" );

 

2 批量拼接字符串到某字段

update 表名 set 字段A = CONCAT( 字段A  , "xxx"  );

update 表名 set 字段A = CONCAT( "yyy" , 字段A  , "xxx"  );

 

3 批量截取某字段,扔掉开始的4个字符

update 表名 set 字段A=SUBSTR(字段A,4);

 

4 批量截取某字段,保留结尾的3个字符
update 表名 set 字段A=SUBSTR(字段A,-3);

 

5 批量截取某字段,去掉结尾的2个字符

update 表名 set 字段A=SUBSTR(字段A,1,LENGTH(字段A)-2);

 

更详细的方法请参考MYSQL的SUBSTR函数

 

特别的思路,可以替换复杂规则的字符(一定要看)

1、将目标数据,借助navicat等工具,可以导出为update sql

2、既然是update纯文本了,就可以用notepad++记事本工具,批量替换了

3、替换时可以用正则匹配替换,正则匹配详见这篇文章  正则匹配html标签_匹配两字符串之间内容_匹配image标签

 

 

------------update+select----------------------------------以下是互联网收集,用的时候再仔细验证

/*
  多表关联update的时候,记得要加exists()条件,否则不满足条件的记录被update称NULL:
  比如:stu表存在,但stu1表不存在的数据,对应的字段会被updat成NULL;
*/

6 多表关联update单字段
update stu t set t.NAME = (select t1.NAME from stu1 t1 where t1.ID = t.ID)
where exists(select 1 from stu1 t2 where t2.ID = t.ID);

7 多表关联update多字段
update stu t set (t.NAME, t.SEX) = (select t1.NAME, t1.SEX from stu1 t1 where t1.ID = t.ID)
where exists(select 1 from stu1 t2 where t2.ID = t.ID);

 

UPDATE table1 alias
SET (column_name,column_name ) = (
SELECT (column_name, column_name)
FROM table2
WHERE column_name = alias.column_name)
WHERE column_name = VALUE

评论 4 您还未登录,请先 登录 后发表或查看评论
©️2022 CSDN 皮肤主题:黑客帝国 设计师:我叫白小胖 返回首页

打赏作者

yfx000

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值