MySQL数据更新操作

文章目录


前言

提示:这里可以添加本文要记录的大概内容:

数据更新有两种办法:

  1. 使用数据可视化工具操作(简单)
  1. SQL语句(容易出错,但必须要会)

添加/插入数据

INSERT语句的基本语法:INSERT INTO 表名(列名列表) VALUES(值列表)

注意:列名列表 与 值列表 永远保持一致!

【例】试把数据"('021B310001','张三', '男', '1999-11-26')和数据('021B310002','李四', '男', '1999-10-20')"插入到Student表中。

sql 复制代码
INSERT INTO Student(stu_ID,name,sex,birthdate)
VALUES('021B310001','张三','男','1999-11-26'),
	  ('021B310002','李四','男','1999-10-20');

要插入的数据如果恰好与表的列数以及各列的顺序保持一致,所以"列名列表"也可以省略掉,变成如下的形式:

sql 复制代码
INSERT INTO Student
VALUES('021B310001','张三','男','1999-11-26')

【例】Student表中插入下面的数据:

学生学号:'021B310002'

学生姓名:'张三'

学生性别:'女'

sql 复制代码
INSERT INTO Student(stu_ID,name,sex)
       VALUES('021B310002','张三','女')
  或者:
INSERT INTO Student
       VALUES('021B310002','张三','女',NULL)

删除数据

语法格式:DELETE FROM 表名 WHERE 条件;

我们在使用某些操作系统时,有时候也会点击删除按钮,看似看不见了,其实数据还在

只是我们看不见了而已,比如说数据可见是1,数据不可见是2。

【例】删除Book表中的全部数据

sql 复制代码
DELETE FROM Book

【例】删除价格大于100元的图书

sql 复制代码
DELETE FROM Book WHERE price>100

【例】删除张三的借阅纪录

子查询方式实现

sql 复制代码
DELETE FROM Borrow WHERE Reader_id IN
(SELECT Reader_id FROM Reader WHERE name='张三')

修改数据

语法格式:UPDATE <表名> SET [WHERE <更新条件>]

【例】所有的图书价格打8折

sql 复制代码
UPDATE Book SET price = price*0.8

【例】所有"清华大学出版社"的图书价格加价15%

sql 复制代码
UPDATE Book SET price = price*1.15 WHERE public='清华大学出版社'

【例】使用library数据库,把张三的出生日期改成1999-03-21

sql 复制代码
update reader set birthdate='1999-03-21' 
where name='张三'

【例】修改reader表中为021B310005的读者的名字改为李四,性别改为男

sql 复制代码
update Reader set name='李四',sex='男'
where Reader_ID='021B310005'

【例】将张三所借图书的日期更改为2022-5-1

子查询方式

sql 复制代码
UPDATE Borrow SET Borrowdate= '2022-5-1'
WHERE reader_ID IN (SELECT reader_ID FROM Reader WHERE name= '张三')

多表连接方式:

sql 复制代码
UPDATE Borrow SET Borrowdate= '2022-5-1'
FROM Borrow JOIN Reader ON Borrow.reader_ID = Reader.reader_ID 
WHERE name= '张三'

更改'张三'借阅'高等数学'的借阅日期为'2022-6-8'

sql 复制代码
UPDATE Borrow SET Borrowdate= '2022-6-8'
    WHERE reader_ID IN 
(SELECT reader_ID FROM Reader
    WHERE name= '张三')
and book_ID IN 
(SELECT book_ID FROM book
    WHERE name= '高等数学')
相关推荐
长城20242 分钟前
关于MySql的ONLY_FULL_GROUP_BY问题
数据库·mysql·聚合列
常常有18 分钟前
MySQL 底层执行原理:输入SQL语句到两阶段提交
数据库·sql·mysql
Mr. zhihao1 小时前
深入解析redis基本数据结构
数据结构·数据库·redis
m0_748839491 小时前
利用天正暖通CAD快速掌握风管数量统计的方法
数据库
随身数智备忘录1 小时前
什么是设备管理体系?设备管理体系包含哪些核心模块?
网络·数据库·人工智能
海市公约2 小时前
MySQL更新语句执行全流程:从Buffer Pool修改到二阶段提交
数据库·mysql·binlog·innodb·undo log·二阶段提交·update执行原理
颂love2 小时前
MySQL的执行流程
android·数据库·mysql
海市公约2 小时前
一条SQL查询的完整旅程:MySQL执行流程深度解析
sql·mysql·数据库优化·执行计划·连接器·查询缓存·sql执行原理
程序leo源2 小时前
Qt窗口详解
开发语言·数据库·c++·qt·青少年编程·c#
这个DBA有点耶3 小时前
COUNT进阶:超大表的近似计数与HyperLogLog
数据库·sql·程序人生·学习方法·dba·改行学it