ToB企服应用市场:ToB评测及商务社交产业平台

标题: Mysql——update更新数据的方式 [打印本页]

作者: 种地    时间: 2024-7-17 19:07
标题: Mysql——update更新数据的方式
注:文章参考:
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 按照不同条件(批量)更新不同值


   update  表名
  set 
       列名1 = if (条件1,值1,值2),
       列名2 = if (条件2,值3,值4)
[where 条件];
  
   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是平均结果)

  1. CREATE TABLE IF NOT EXISTS students (
  2. id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
  3. name varchar(8) NOT NULL COMMENT '姓名',
  4. score int NOT NULL COMMENT '成绩'
  5. )CHARACTER SET utf8 COLLATE utf8_general_ci;
  6. INSERT INTO students(name,score)VALUES
  7. ('嘟嘟',99),
  8. ('吱吱',67),
  9. ('哦莫',59);
复制代码

       代码及输出结果为:
  1. #使用where
  2. update students
  3. set score = 100
  4. where name = '嘟嘟';
复制代码


      代码及输出结果为:
  1. update students
  2. set score = replace(score,59,0),
  3. name = replace(name,'吱','七')
  4. where id >=2;
复制代码


      代码及输出结果为:
  1. --- 批量更新多值 + if
  2. update  students
  3. set
  4.    score = if(score < 60,0,100),
  5.    name = if(score < 60,'不及格','及格');
复制代码


       代码及输出结果为:
  1. #批量更新多值 + case when
  2. update students
  3. set
  4.     name = case
  5.         when score < 60 then '不及格'
  6.                 when score >= 90 then '优秀'
  7.         else '良好'
  8.     end,
  9.                 score = case
  10.         when score < 60 then 0
  11.                 when score >= 90 then 2
  12.         else 1
  13.     end;
复制代码


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4