种地 发表于 2024-7-17 19:07:10

Mysql——update更新数据的方式

注:文章参考:
MySQL 更新数据 不同条件(批量)更新不同值_update批量更新同一列不同值-CSDN博客文章浏览阅读2w次,点赞20次,收藏70次。一般在更新时会碰到以下场景:1.全部更新;2.根据条件更新字段中的某部分内容;3.根据不同的条件更新不同的值,以下是几种场景中常用的update方法。_update批量更新同一列不同值https://g.csdnimg.cn/static/logo/favicon32.icohttps://blog.csdn.net/chengyj0505/article/details/128357191    本篇主要介绍mysql数据库中的不同条件批量更新不同的值。更新时会碰到以下场景:
   1.全部更新;
2.根据条件更新字段中的某部分内容;
3.根据不同的条件更新不同的值
以下是几种场景中常用的update方法。
一、场景分类

https://img-blog.csdnimg.cn/direct/fc9e10e9d7af4c3cbf7df2bd2dd8be01.png
二、具体用法

2.1 根据条件更新值



[*] 根据指定条件更新(多列)(全部更新)
      把表中 [符合条件的行的] 列名1字段中的值全部修改为值1  [,列名2字段中的值修改为值2]。
   语法:
update 表名
 set  列名1 =值1 [,列名2 = 值2]
 ;


[*]替换指定值(多列)(部分更新)
       把表中 [符合条件的行的] 列名1字段中的查找内容全部修改为替换内容 [,列名2字段中的查找内容全部修改为替换内容]。
   语法:
update 表名 
set 列名1  =  replace(列名1, '查找内容', '替换内容')  [, 列名2 = replace(列名2, '查找内容', '替换的内容')] 
;
2.2 按照不同条件(批量)更新不同值



[*]使用if
   update  表名
set 
     列名1 = if (条件1,值1,值2),
     列名2 = if (条件2,值3,值4)
;


[*]使用case when
   update  表名
set 
     列名1 =
     case 
            when 条件1 then 值1
            when 条件2 then 值2
            when 条件3 then 值3
            ...
     end,
     列名2 =
     case 
            when 条件12 then 值12
            when 条件22 then 值22
            when 条件32 then 值32
            ......
       end
;
ps:留意更新的值要满足建表时的字段范例,例如字段A建表时是int范例,update更新的时候,不能更新为varchar范例等
三、实例

students 表 (id表示主键,name是姓名,score是平均结果)
https://img-blog.csdnimg.cn/direct/7ec4cbdc93d14739ab84a88d87c3057f.png
CREATE TABLE IF NOT EXISTS students (
id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
name varchar(8) NOT NULL COMMENT '姓名',
score int NOT NULL COMMENT '成绩'
)CHARACTER SET utf8 COLLATE utf8_general_ci;


INSERT INTO students(name,score)VALUES
('嘟嘟',99),
('吱吱',67),
('哦莫',59);

[*] 把表中 name 为嘟嘟的 score值全部修改为100。
       代码及输出结果为:
#使用where
update students
set score = 100
where name = '嘟嘟'; https://img-blog.csdnimg.cn/direct/17c8445ec7c24e0b8ce2cc22f999c9de.png


[*] 把表中 id>=2的全部行中 score等于59的全部修改为0,name 中‘嘟’的修改为‘七’
      代码及输出结果为:
update students
set score = replace(score,59,0),
name = replace(name,'吱','七')
where id >=2; https://img-blog.csdnimg.cn/direct/d28f087ea95244d092bfd52db3c57e33.png


[*] 表中score小于60的score字段全部改为0,否则改为100,name字段中的名字改为不及格,否则改为及格
      代码及输出结果为:
--- 批量更新多值 + if
updatestudents
set
   score = if(score < 60,0,100),
   name = if(score < 60,'不及格','及格'); https://img-blog.csdnimg.cn/direct/e128d2e8c24e44a7bf75f82aed1e1056.png


[*] 把表中score小于60的score字段全部改为0,name字段中的名字改为不及格;score大于等于90的score字段全部改为2,name字段中的名字改为优秀;score大于等于60小于90的score字段全部改为1,name字段中的名字改为良好。
       代码及输出结果为:
#批量更新多值 + case when
update students
set
    name = case
      when score < 60 then '不及格'
                when score >= 90 then '优秀'
      else '良好'
    end,
                score = case
      when score < 60 then 0
                when score >= 90 then 2
      else 1
    end;
https://img-blog.csdnimg.cn/direct/4e89906c9ea147d381ceedcd1ad84d5a.png

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: Mysql——update更新数据的方式