MySQL实现数据更新的示例详解
来源:脚本之家
时间:2023-02-25 08:57:00 176浏览 收藏
哈喽!今天心血来潮给大家带来了《MySQL实现数据更新的示例详解》,想必大家应该对数据库都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到MySQL数据、更新,若是你正在学习数据库,千万别错过这篇文章~希望能帮助到你!
一般在更新时会遇到以下场景:
1.所有字段全部更新;
2.根据条件更新字段中的某部分内容;
3.根据不同的条件更新不同的值
以下是几种场景中常用的update方法。
一、方法分类
二、具体用法
(1)根据条件更新值
根据指定条件更新(多列)(全部更新)
把表中 [符合条件的行的] 列名1字段中的值全部修改为值1 [,列名2字段中的值修改为值2]。
update 表名 set 列名1 = 值1 [,列名2=值2] [where 条件];
替换指定值(多列)(部分更新)
把表中 [符合条件的行的] 列名1字段中的查找内容全部修改为替换内容 [,列名2字段中的查找内容全部修改为替换内容]。
update 表名 set 列名1 = replace(列名1, '查找内容', '替换内容') [,列名2 = replace(列名2, '查找内容', '替换内容')] [where 条件];
(2)按照不同条件(批量)更新不同值
使用 if
把表中 [符合条件的行的] 列名1字段中符合条件1的内容修改为值1,否则修改为值2 [,列名2字段中符合条件2的内容修改为值3,否则修改为值4]。
update table set 列名1 = if(条件1,值1,值2), 列名2 = if(条件2,值3,值4) [where 条件];
使用 case when
把表中 [符合条件的行的] 列名1字段中符合条件1的内容修改为值1 [,符合条件2的修改为值2,...] [,列名2字段中符合条件21的内容修改为值21,符合条件22的修改为值22,...] 。
update table set 列名1 = case when 条件1 then 值1 when 条件2 then 值2 when 条件3 then 值3 ... end, 列名2 = case when 条件21 then 值21 when 条件22 then 值22 when 条件23 then 值23 ... end [where 条件];
三、实例
students 表 (id表示主键,name是姓名,score是平均成绩)
id | name | score |
---|---|---|
1 | 李明 | 99 |
2 | 张三 | 74 |
3 | 孙华 | 59 |
(1)根据条件更新值
把 students 表中 name 为张三的 score 字段的值全部修改为100。
#使用where update students set score = 100 where name = '张三';
id | name | score |
---|---|---|
1 | 李明 | 99 |
2 | 张三 | 100 |
3 | 孙华 | 59 |
把 students 表中 id 大于等于2的所有行中 score 中59的部分全部修改为0,name 中三的部分全部修改为四。
#使用replace update students set score = replace(score,59,0), name = replace(name,'三','四') where id >= 2;
注意:张三替换之后是张四,并不是只有字段等于三时才能替换。
id | name | score |
---|---|---|
1 | 李明 | 99 |
2 | 张四 | 74 |
3 | 孙华 | 0 |
(2)按照不同条件更新不同值
请把students表中score小于60的score字段全部改为0,否则改为100,name字段中的名字改为不及格,否则改为及格。
#批量更新多值 + if update students set score = if(score
id | name | score |
---|---|---|
1 | 及格 | 100 |
2 | 及格 | 100 |
3 | 不及格 | 0 |
注意:更新的值要满足建表时的字段类型。比如score是int类型就不能更新为char类型。
请把students表中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 = 90 then '优秀' else '良好' end, score = case when score = 90 then 2 else 1 end;
注意:更新的时候是按照代码语句的先后顺序更新的。可以尝试先更新score后更新name,结果是不一样的。
id | name | score |
---|---|---|
1 | 优秀 | 2 |
2 | 良好 | 1 |
3 | 不及格 | 0 |
文中关于mysql的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《MySQL实现数据更新的示例详解》文章吧,也可关注golang学习网公众号了解相关技术文章。
-
443 收藏
-
311 收藏
-
146 收藏
-
236 收藏
-
336 收藏
-
184 收藏
-
237 收藏
-
210 收藏
-
192 收藏
-
364 收藏
-
373 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习