Mysql——update更新数据的方式
作者:mmseoamin日期:2024-04-27

注:文章参考:

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

1.全部更新;

2.根据条件更新字段中的某部分内容;

3.根据不同的条件更新不同的值

以下是几种场景中常用的update方法。

一、场景分类

Mysql——update更新数据的方式,第2张

二、具体用法

2.1 根据条件更新值

  • 根据指定条件更新(多列)(全部更新)

          把表中 [符合条件的行的] 列名1字段中的值全部修改为值1  [,列名2字段中的值修改为值2]。

    语法:

    update 表名

     set  列名1 =值1 [,列名2 = 值2]

     [where 条件];

    • 替换指定值(多列)(部分更新)

             把表中 [符合条件的行的] 列名1字段中的查找内容全部修改为替换内容 [,列名2字段中的查找内容全部修改为替换内容]。

      语法:

      update 表名 

      set 列名1  =  replace(列名1, '查找内容', '替换内容')  [, 列名2 = replace(列名2, '查找内容', '替换的内容')] 

      [where 条件];

      2.2 按照不同条件(批量)更新不同值

      • 使用if

        update  表名

        set 

             列名1 = if (条件1,值1,值2),

             列名2 = if (条件2,值3,值4)

        [where 条件];

        • 使用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

          [where 条件];

          ps:注意更新的值要满足建表时的字段类型,例如字段A建表时是int类型,update更新的时候,不能更新为varchar类型等

          三、实例

          students 表 (id表示主键,name是姓名,score是平均成绩)

          Mysql——update更新数据的方式,第3张

          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 = '嘟嘟';

            Mysql——update更新数据的方式,第4张

            • 把表中 id>=2的所有行中 score等于59的全部修改为0,name 中‘嘟’的修改为‘七’

                    代码及输出结果为:

              update students
              set score = replace(score,59,0),
              name = replace(name,'吱','七')
              where id >=2;

              Mysql——update更新数据的方式,第5张

              • 表中score小于60的score字段全部改为0,否则改为100,name字段中的名字改为不及格,否则改为及格

                      代码及输出结果为:

                --- 批量更新多值 + if
                update  students
                set
                   score = if(score < 60,0,100),
                   name = if(score < 60,'不及格','及格');

                Mysql——update更新数据的方式,第6张