【MySQL】表的增删改查(基础)

一、新增(Create)

先创建一张表:

sql 复制代码
create table student (id int,sn int comment '学号',name varchar(20),email varchar(20));

1.1 单行数据 + 全列插入

插入两条记录,value_list 数量必须和定义表的列的数量及顺序一致

sql 复制代码
insert into student values (100,10000,'孙悟空','1111@qq.com');
insert into student values (200,20000,'猪八戒','2222@qq.com');

1.2 多行数据 + 指定列插入

插入两条记录,value_list 数量必须和指定列数量及顺序一致

sql 复制代码
insert into student (id,sn,name) values (300,30000,'沙悟能'),(400,40000,'唐僧');

最后得到的student

二、查询(Retrieve)

创建考试成绩表:

sql 复制代码
 create table exam_result (
 id int,
 name varchar(20),
 chinese decimal(3,1),
 math decimal(3,1),
 english decimal(3,1)
 );

插入测试数据:

sql 复制代码
insert into exam_result (id,name,chinese,math,english) values (1,'唐三藏', 67, 98, 56),
(2,'孙悟空', 87.5, 78, 77),
(3,'猪悟能', 88, 98.5, 90),
(4,'曹 孟德', 82, 84, 67),
(5,'刘玄德', 55.5, 85, 45),
(6,'孙权', 70, 73, 78.5),
(7,'宋公明', 75, 65, 30);

2.1 全列查询

sql 复制代码
select * from exam_result;

2.2 指定列查询

sql 复制代码
select id,name,math from exam_result;

2.3 查询字段为表达式

sql 复制代码
表达式不包含字段:
select id,name,10 from exam_result;
表达式包含一个字段:
select id,name,math+10 from exam_result;
表达式包含多个字段:
select id,name,chinese+math+english from exam_result;

2.4 别名

sql 复制代码
select id,name,chinese+math+english 总分 from exam_result;

2.5 去重:distinct

sql 复制代码
select distinct math from exam_result;

2.6 排序:order by

sql 复制代码
-- ASC 为升序(从小到大)
-- DESC 为降序(从大到小)
-- 默认为 ASC
select name,chinese from exam_result order by chinese;
select name,chinese from exam_result order by chinese desc;


2.7 条件查询 where



注意:
🚕(1)where条件可以使用表达式,但不能使用别名。
🚕(2)and的优先级高于or,在同时使用时,需要使用小括号()包裹优先执行的部分

sql 复制代码
查询英语不及格的同学及英语成绩 ( < 60 )
select english from exam_result where english < 60;
sql 复制代码
查询语文成绩好于英语成绩的同学
select chinese,english from exam_result where chinese > english;
sql 复制代码
查询语文成绩大于80分,或英语成绩大于80分的同学
select chinese,english from exam_result where chinese > 80 or english > 80;
sql 复制代码
查询语文成绩在 [80, 90] 分的同学及语文成绩
select chinese from exam_result where chinese between 80 and 90;
sql 复制代码
查询数学成绩是 58 或者 59 或者 98 或者 99 分的同学及数学成绩
select name,math from exam_result where math in (58,59,98,99);
sql 复制代码
模糊查询like:
% 匹配任意多个(包括 0 个)字符:
select name from exam_result where name like '孙%';
_ 匹配严格的一个任意字符
select name from exam_result where name like '孙_';

3.8 分页查询 limit

sql 复制代码
按 id 进行分页,每页 3 条记录,分别显示 第 1、2、3 页:

第一页:从 0 开始,筛选 3 条结果
select id, name, math, english, chinese from exam_result order by id limit 3 offset 0;

第二页:从 3 开始,筛选 3 条结果
select id, name, math, english, chinese from exam_result order by id limit 3 offset 3;

第三页:从 6 开始,筛选 3 条结果(结果不足不会有影响)
select id, name, math, english, chinese from exam_result order by id limit 3 offset 6;

三、修改(Update)

sql 复制代码
将孙悟空同学的数学成绩变更为 80 分
update exam_result set math=80 where name='孙悟空';

将总成绩倒数前三的 3 位同学的英语成绩加上 30 分
update exam_result set english = english + 30 order by chinese+math+english limit 3;

四、删除(Delete)

sql 复制代码
删除孙悟空同学的考试成绩:
delete from exam_result where name = '孙悟空';

删除整表数据:
delete from exam_result;
相关推荐
_qingche5 小时前
H2 数据库到 MySQL 数据迁移
java·数据库·spring boot·mysql·spring·重构·kotlin
AOwhisky5 小时前
MySQL 学习笔记(第一期):数据库基础与 MySQL 初探
运维·数据库·笔记·学习·mysql·云计算
数据库小学妹6 小时前
MySQL ORDER BY 深度解析:Using temporary 与 Using filesort 的底层机制及索引优化实战
数据库·经验分享·mysql·性能优化·dba
可乐ea6 小时前
【知识获取与分享社区项目 | 项目日记第 21 天】索引构建与联想建议:Outbox 增量更新 + Completion Suggester
java·大数据·mysql·elasticsearch·搜索引擎
AI人工智能+电脑小能手6 小时前
【大白话说Java面试题 第93题】【Mysql篇】第23题:从查找速度来看,聚集索引和非聚集索引哪个更快?
java·开发语言·数据库·mysql·面试
WPF工业上位机6 小时前
YXGK.FakeVM数据库示例
jvm·数据库·oracle
牛奔6 小时前
如何让 GORM 打印 SQL 语句?三种方式全解析
数据库·sql
XWalnut7 小时前
Redis从入门到精通
数据库·redis·缓存
andafaAPS7 小时前
安达发|工艺品aps自动排产排程排单软件:告别生产“一团乱麻“
大数据·数据库·人工智能·安达发aps·计划排产软件·自动排单软件
zt1985q7 小时前
本地部署源代码管理解决方案 Bitbucket Data Center 并实现外部访问
运维·服务器·数据库·网络协议·postgresql·源代码管理