Mysql——更新数据

注:文章参考:

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

1.全部更新;

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

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

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

一、场景分类

、具体用法

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是平均成绩)

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

 

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

      代码及输出结果为:

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

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

      代码及输出结果为:

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

  • 把表中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;

相关推荐

  1. MySQL数据库——10、UPDATE 更新

    2024-02-10 04:02:02       21 阅读
  2. MySQL模块---更新和删除数据

    2024-02-10 04:02:02       19 阅读
  3. MySQLmysql数据库小功能整理,持续更新~

    2024-02-10 04:02:02       18 阅读
  4. Mysql数据处理常用sql模板·持续更新...

    2024-02-10 04:02:02       34 阅读

最近更新

  1. 基于go 1.19的站点模板爬虫

    2024-02-10 04:02:02       0 阅读
  2. Pandas在生物信息学中的应用详解

    2024-02-10 04:02:02       0 阅读
  3. DOM XMLHttpRequest

    2024-02-10 04:02:02       1 阅读
  4. nginx详解

    2024-02-10 04:02:02       1 阅读
  5. vue实现表单输入框数字类型校验功能

    2024-02-10 04:02:02       1 阅读
  6. Perl 语言入门学习

    2024-02-10 04:02:02       1 阅读

热门阅读

  1. 什么是集群服务器

    2024-02-10 04:02:02       34 阅读
  2. Linux中的numactl命令指南

    2024-02-10 04:02:02       27 阅读
  3. CSS3

    CSS3

    2024-02-10 04:02:02      34 阅读
  4. Blend for Visual Studio 工具作用

    2024-02-10 04:02:02       26 阅读
  5. PMP考试之20240209

    2024-02-10 04:02:02       29 阅读
  6. 机器学习之正态分布

    2024-02-10 04:02:02       24 阅读
  7. python学习笔记 -- 字符串

    2024-02-10 04:02:02       30 阅读
  8. 广义表-C语言

    2024-02-10 04:02:02       29 阅读
  9. leetcode-hot100树的专题

    2024-02-10 04:02:02       31 阅读