【MySQL — 数据库增删改查操作】深入解析MySQL的 Update 和 Delete 操作


1. 测试数据


sql 复制代码
mysql> select* from exam1;
+------+-----------+---------+------+---------+
| id   | name      | Chinese | Math | English |
+------+-----------+---------+------+---------+
|    1 | 唐三藏    |    67.0 | 98.0 |    56.0 |
|    2 | 孙悟空    |    87.0 | 78.0 |    77.0 |
|    3 | 猪悟能    |    88.0 | 98.0 |    90.0 |
|    4 | 曹孟德    |    82.0 | 84.0 |    67.0 |
|    5 | 刘玄德    |    55.0 | 85.0 |    45.0 |
|    6 | 孙权      |    70.0 | 73.0 |    78.0 |
|    7 | 宋公明    |    75.0 | 65.0 |    30.0 |
| NULL | NULL      |    NULL | NULL |    90.0 |
+------+-----------+---------+------+---------+
8 rows in set (0.00 sec)

2. Update 修改


update操作,是真正在改硬盘了;这样的修改是"持久有效" 的,所以一定要确保 update 的修改是改对的;

sql 复制代码
update 表名 set 列名 = 值,列名 = 值.....;

语法


sql 复制代码
UPDATE [LOW_PRIORITY] [IGNORE] table_reference
    SET assignment[,assignment]...        
    [WHERE where_condition]
    [ORDER BY ...]
    [LIMIT row_count]

    -- set 在这里的意思是设置

示例


更新操作


一次修改一个列


把孙悟空数学成绩修改成 80

sql 复制代码
update exam1 set Math = 80 where name = '孙悟空';

Query OK, 1 row affected (0.06 sec)

Rows matched: 1  Changed: 1  Warnings: 0  -- 匹配和修改一行数据

把所有数学成绩在原有基础上加10分

sql 复制代码
update exam1 set Math = Math + 10 where id is not null;

ERROR 1264 (22003): Out of range value for column 'Math' at row 1

-- 超出 decimal(3,1)的范围,此时是真正修改硬盘数据,所以修改失败

把所有数学成绩在原有基础上减10分

sql 复制代码
update exam1 set Math = Math - 10 ;

Query OK, 7 rows affected (0.01 sec)

Rows matched: 8  Changed: 7  Warnings: 0

-- 匹配的行数和修改的行数不同,说明如果修改的数据基础是 null,则无法修改

一次修改多个列


把曹孟德的语文成绩修改为60,数学成绩修改为70

sql 复制代码
update exam1 set Chinese = 60 , Math = 70 where name = '曹孟德';

Query OK, 1 row affected (0.01 sec)

Rows matched: 1  Changed: 1  Warnings: 0

引入 order by 操作


将总成绩倒数前三的3位同学的数学成绩加上20分

sql 复制代码
-- 查看总分倒数前三的同学

select* from exam1 
    where Chinese + Math + English is not null 
    order by  Chinese + Math + English limit 3;


-- 更新总分倒数前三的同学的数学成绩

update exam1 set Math = Math + 20 
    where Chinese + Math + English is not null 
    order by  Chinese + Math + English limit 3;

特殊情况:好几个同学成绩相同,倒数前三的成绩里有不止3个同学


Update 注意事项



3. Delete 删除


语法


sql 复制代码
DELETE FROM tbl_name  [WHERE where_condition] [ORDER BY ...] [LIMIT row_count]

delete from 表名 where 条件/ order by / limit;

示例


删除操作


删除孙悟空同学的考试成绩


sql 复制代码
delete from exam1 where name = '孙悟空';

Query OK, 1 row affected (0.01 sec)

Delete 注意事项



相关推荐
岁岁种桃花儿5 小时前
MySQL从入门到精通系列:InnoDB记录存储结构
数据库·mysql
jiunian_cn7 小时前
【Redis】hash数据类型相关指令
数据库·redis·哈希算法
冉冰学姐7 小时前
SSM在线影评网站平台82ap4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm框架·在线影评平台·影片分类
Exquisite.8 小时前
企业高性能web服务器(4)
运维·服务器·前端·网络·mysql
知识分享小能手8 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019数据库的操作(2)
数据库·学习·sqlserver
踩坑小念9 小时前
秒杀场景下如何处理redis扣除状态不一致问题
数据库·redis·分布式·缓存·秒杀
萧曵 丶10 小时前
MySQL 语句书写顺序与执行顺序对比速记表
数据库·mysql
Wiktok10 小时前
MySQL的常用数据类型
数据库·mysql
曹牧11 小时前
Oracle 表闪回(Flashback Table)
数据库·oracle
J_liaty11 小时前
Redis 超详细入门教程:从零基础到实战精通
数据库·redis·缓存