MySQL中表的增删查改操作(CRUD)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL中表的增删查改操作(CRUD)

所谓的CRUD即增加(Create), 查询(Retrieve), 更新(Update), 删除(Deleete)四种操作.

这里在开头补充一下sql当中的注释可以使用"–空格+描述"来表示注释说明.


一. 新增

我们这里先创建一张学生表来演示对表的相关操作.

-- 创建一张学生表
create database student
(
    id int,
    sn int, -- 学号
    name varchar(20), -- 姓名
    mail varchar(20) -- qq邮箱
);

mysql中通过insert关键字来插入(新增)记录.


1. 全列插入

语法:

insert into 表名 values(对应列的实参列表); -- 一次插入一行
insert into 表名 values(对应列的实参列表), (对应列的实参列表).... -- 一次插入多行

注意:


values 后面( )中的内容, 个数和类型要和表的结构匹配.


示例:

-- 单行插入
insert into student values(101, 10001, '喜羊羊', '12345');
-- 多行插入
insert into student values
(102, 10002, '美羊羊', '23456'), 
(103, 10003, '懒羊羊', '34567'),
(104, 10004, '沸羊羊', '45678');

插入结果:

73d8c9be8b2a4960a39693770de0ac9a.png


有关日期数据的插入, 尽量使用datetime, 日期的插入格式为 : yyyy-mm-dd hh:mm:ss, 其中now()能够获取当前日期。

create table times (id int, time datetime);
insert into times values (1, '2022-08-12 13:14:00'), (2, now());

2. 指定列插入

语法:

insert into 表名 (需要插入的列) values(对应列的实参列表); -- 一次插入一行
insert into 表名 (需要插入的列)values(对应列的实参列表), (), ().... -- 一次插入多行

注意:

values 后面( )中的内容, 个数和类型要和表名后面( )中指定的结构匹配.

未被指定的列会以默认值进行填充.

示例:

-- 单行插入
insert into student (id, name) values(105, '暖羊羊');
--多行插入
insert into student (id, name) values
(106, '慢羊羊'), (107, '灰太狼'), (108, '红太狼');

插入结果:

73d8c9be8b2a4960a39693770de0ac9a.png

3. 效率问题

在mysql当中, 多条记录逐次插入的效率是要低于一次把多条纪录一起插入的.


具体受如下方面的影响:


网络请求和响应的时间开销引起, 多次请求和响应的时间开销更大.

数据库服务器是把数据保存在硬盘上的, 在进行lO操作的时候,数据量会对效率有影响, 但是影响一般不会很大, 更大的则是IO操作的次数.

mysql关系型数据库, 每次进行一个sql操作, 内部都会开启一个事务, 每次开启事务也有一定的时间开销.

补充:内存和外存的区别.


内存上读写数据的速度快 ,外存的读写速度慢(速度能差3-4个数量级,也就是几千倍,甚至上万倍).

内存空间比较小,外存空间比较大(比如电脑配置内存16GB,外存是512GB).

内存比外存贵.

内存的数据"易失", 断电之后, 数据就会丢失; 外存的数据是 “持久” 的,断电之后,数据还在.

二. 查询(Retrieve)

mysql中通过select关键字来完成查询操作.

1. 全列查询(整表查询)

语法:

select * from 表名;

注意:


上面的 * 表示通配符, 可以匹配表中的所有列.

这个操作要慎重使用, 在企业级别的数据库中, 数据量是非常大的(TB级别), 查询操作会遍历所有的数据,把数据从硬盘上读出来通过网卡来发送到客户端上, 同时硬盘读写也是有限的, 这样的操作, 如果数据量非常大, 就容易把 IO 吃满, 或者把网络宽带吃满; 此时如果有外面的用户客户端要通过宽带访问服务器时, 服务器就无法及时做出响应.

示例:


查询上面创建的学生表和日期表.

select * from student;
select * from times;

查询结果:

73d8c9be8b2a4960a39693770de0ac9a.png


注意: 这里查询结果所显示的表是服务器端数据库返回给客户端的一个临时表,使用查询操作不会对服务器中的数据造成影响, 该临时表在客户端打印后就销毁了.


2. 指定列查询

语法:

select 列名, 列名, ... from 表名;

示例:


查询学生表中的姓名和邮箱,

select name, mail form student;

插入结果:

73d8c9be8b2a4960a39693770de0ac9a.png

3. 指定字段表达式运算查询

这里再创建一张考试成绩表如下:

-- 创建考试成绩表
create table exam_result (
    id int, 
    name varchar(20), -- 姓名
    chinese decimal(3, 1), -- 语文成绩
    math decimal(3, 1), -- 数学成绩
    english decimal(3, 1) -- 英语成绩
);
-- 插入数据
insert into exam_result 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, '潇洒哥', null, 75, 65);

语法:

select 字段或表达式, 字段或表达式... from 表名;

注意:

这里的表达式运算是同一行中不同列之间的运算, 是不可以跨行进行运算的.

示例:

查询将语文成绩和数学成绩在原来的基础上减少10分的结果,

select * from exam_result;
select name, chinese-10, math-10 from exam_result;

查询结果:

73d8c9be8b2a4960a39693770de0ac9a.png

4. 将表达式或字段指定别名查询

上面的查询结果中显示的表头是一个表达式, 但如果这一个表达式很长时就不适合作为表头显示了, mysql中支持在查询时给表达式起一个别名, 让查询结果直接显示别名, 查询结果更加直观.


语法:

select 列名或表达式 as 别名, ... from 表名;

注意:

上面的as可以省略, 但是不建议省略, 省略以后代码的可读性变差, 而且容易出错;


示例:

查询成绩表中每个人的总成绩和平均成绩.

select name, chinese+math+english as total, 
(chinese+math+english)/4 as average from exam_result;

查询结果:

73d8c9be8b2a4960a39693770de0ac9a.png

注意 :

73d8c9be8b2a4960a39693770de0ac9a.png

有null参与的运算最终的结果还是为null.

每一个列或者表达式的别名只在当前字段有效, 如果运用到下一个字段就会报错

5. 去重查询

mysql支持对列的去重查询, 重复的数据只会输出一个, 用关键字distinct来表示去重.


语法:

select distinct 列名 from 表名;

注意:


去重查询只支持单列进行去重, 如果一次查询多列就会失去去重效果.

示例:


先插入三个人的成绩, 使三人的英语成绩相同, 然后对英语成绩进行去重查询.

nsert into exam_result values 
(8, '灰太郎', 55, 65, 88),
(9, '红太狼', 85.5, 78, 88),
(10, '小白狼', 78, 88, 88);
select english from exam_result;
select distinct english from exam_result;

查询结果:

73d8c9be8b2a4960a39693770de0ac9a.png

看查询结果英语成绩中有三个88, 最后只显示输出了一个88, 达到了去重效果.


6. 排序查询

将要查寻的数据排序得到临时表输出, 排序相关的关键字order by.

语法:

select 列名, ... from 表名 order by 列名(要排序的列) asc(或者desc), ...;

注意:


上面末尾的asc表示升序, 升序查询时asc可以省略; desc表示降序查询.

如果查询的数据当中存在 null, 那么null默认是最小的.

当排序指定多个列时, 不是去将每列单独进行排序, 指定多个列属于复杂规则的比较, 比如指定的两个列, 先以第一个列的比较规则为准, 如果第一列的规则比较不出结果, 再去按第二列的规则去比较, 多个列以此类推.

示例:

  • 查询上面成绩的总分(降序).
select name, chinese+math+english as total from exam_result order by total desc;

查询结果:

73d8c9be8b2a4960a39693770de0ac9a.png


  • 指定英语(降序)和数学(升序)两个列进行排序查询.
select name, english, math from exam_result order by english desc, math asc;

查询结果:

73d8c9be8b2a4960a39693770de0ac9a.png

7. 条件查询

条件查询就是通过设定的条件, 将满足条件的记录查询显示, mysql中通过关键字where + 条件来设置查询条件.

语法:

select 列名, ... from 表名 where 条件;

要正确的设置条件是离不开运算符的, 下面列出mysql中常用的运算符.


比较运算符:

运算符 说明
>, >=, <, <= 大于,大于等于,小于,小于等于
= 等于,null 不安全,例如 null = null 的结果是 null(false)
<=> 等于,null 安全,例如 null <=> null 的结果是 true(1)
!=, <> 不等于
between a0 and a1 范围匹配,[a0, a1],如果 a0 <= value <= a1,返回 true(1)
in (option, …) 如果是 option 中的任意一个,返回 true(1)
is null 是 null
is not null 不是 null
lisk 模糊匹配; % 表示任意多个(包括 0 个)任意字符;_ 表示任意一个字符

逻辑运算符:

运算符 说明
and 多个条件必须都为 true(1),结果才是 true(1)
or 任意一个条件为 true(1), 结果为 true(1)
not 条件为 true(1),结果为 false(0)
  1. where条件可以使用表达式,但不能使用别名。
  2. and的优先级高于or,在同时使用时,需要使用小括号()包裹优先执行的部分

示例:

  • >=…

查询英语成绩不及格的同学及英语成绩(小于60)

查询语文成绩好于英语成绩的同学

查询总分在 200 分以下的同学

-- 查询英语不及格的同学及英语成绩 ( < 60 )
select name, english from exam_result where english < 60;
-- 查询语文成绩好于英语成绩的同学
select name, chinese, english from exam_result where chinese > english;
-- 查询总分在 200 分以下的同学
select name, chinese+math+english as total from exam_result
where chinese+math+english < 200;

73d8c9be8b2a4960a39693770de0ac9a.png

  • and 和 or

查询语文成绩大于80分,且英语成绩大于80分的同学

查询语文成绩大于80分,或英语成绩大于80分的同学

查询语文成绩和数学成绩要有一门大于80且英语成绩要大于70的同学

-- 查询语文成绩大于80分,且英语成绩大于80分的同学
select * from exam_result where chinese > 80 and english > 80;
-- 查询语文成绩大于80分,或英语成绩大于80分的同学
select * from exam_result where chinese > 80 or english > 80;
-- 查询成绩语文成绩和数学成绩要有一门大于80且英语成绩要大于70的同学
select * from exam_result where 
(chinese > 80 or math > 80) and english > 70;

73d8c9be8b2a4960a39693770de0ac9a.png

  • 范围查询( between and, in( ) );

查询语文成绩在 [80, 90] 分的同学及语文成绩

查询数学成绩是 58 或者 59 或者 98 或者 99 分的同学及数学成绩

-- 查询语文成绩在 [80, 90] 分的同学及语文成绩
select name, chinese from exam_result where chinese between 80 and 90;
-- 也可以使用and实现
select name, chainese from exam_result where chainese >= 80 and chainese <= 90;
-- 查询数学成绩是 58 或者 59 或者 98 或者 99 分的同学及数学成绩
select name, math from exam_result where math in (58, 59, 98, 99);
-- 也可以使用or实现
select name, math from exam_result where math = 58 or math = 59 or math = 98, math = 99;

73d8c9be8b2a4960a39693770de0ac9a.png

  • 模糊查询(like)

查找名字含有羊的同学

select * from exam_result where name like '%羊%';

73d8c9be8b2a4960a39693770de0ac9a.png

查找姓名最后一个字为狼的同学

select * from exam_result where name like '%狼';
select * from exam_result where name like '__狼';

73d8c9be8b2a4960a39693770de0ac9a.png

注意 :%可通配多个字符, 而_只能通配一个字符.

  • null的查询(is null / is not null)

查询语文成绩为null的同学

查询语文成绩不为null的同学

-- 查询语文成绩为null的同学
select name, chinese from exam_result where chinese is null;
-- 查询语文成绩不为null的同学
select name, chinese from exam_result where chinese is not null;

73d8c9be8b2a4960a39693770de0ac9a.png

判断是否为null也可以使用<=>null, 这里要注意<=>nullis null的区别,

is null要求只能比较一个列是否为空, 而<=>可以直接比较两个列.


8. 分页查询

现实中分页查询最常见的例子就是浏览器搜索了, 浏览器搜索不会一次性将搜索到的结果都加载显示出来, 而是像下图中将搜索结果按页进行加载呈现, 这种搜索模式就是分页查询;

73d8c9be8b2a4960a39693770de0ac9a.png

mysql中也支持分页查询, 使用关键字limit和offset来实现.

语法:

select 列名, ... from 表名 limit 限制个数 offset 起始下标;
select 列名, ... from 表名 limit 限制个数, 起始下标;

注意:


分页查询本质上就是限制查询结果的条数,你可以设置最多输出几条结果,同时也可以指定从哪一条结果开始查询.

分页查询也可以搭配排序和条件等其他语句使用.

上面的offset可以省略, 但不建议省略, 会使代码的可读性变差, 且省略后代码容易出错.

示例:

  • 以分页的方式上面的成绩表, 每页最多查询三条记录.
-- 第一页
select * from exam_result limit 3 offset 0;
-- 第二页
select * from exam_result limit 3 offset 3;
-- 第三页
select * from exam_result limit 3 offset 6;
-- 剩下的记录
select * from exam_result limit 3 offset 9;

73d8c9be8b2a4960a39693770de0ac9a.png

  • 查询语文成绩前三名的同学.
select * from exam_result order by chinese desc limit 3;

73d8c9be8b2a4960a39693770de0ac9a.png

三. 修改(Update)

mysql中使用关键字updata来表示修改.

语法:

update 表名 set 列名 = 值, 列名 = 值, ... where 限制条件下修改;

注意:


如果不加限制条件修改的就是列中的所有记录.

除了搭配 where 外, 也可以搭配order 和 limit 使用

示例:

  • 将喜羊羊的英语成绩修改为99.
select * from exam_result where name = '喜羊羊';
update exam_result set english = 99 where name = '喜羊羊';
select * from exam_result where name = '喜羊羊';

73d8c9be8b2a4960a39693770de0ac9a.png


将总成绩在前三名的同学的语文成绩再加上10分.

select * from exam_result order by chinese+math+english desc limit 3;
update exam_result set chinese = chinese+10 order by chinese+math+english desc limit 3;
select * from exam_result order by chinese+math+english desc limit 3;


四. 删除(Delete)

mysql中使用关键字delete来表示删除.

语法:

delete from 表名 where 限制条件下删除;

注意:


如果不加限制条件删除的就是表中的所有记录.

除了搭配 where 外, 也可以搭配order 和 limit 使用

示例:

删除潇洒哥的成绩

select * from exam_result;
delete from exam_result where name = "潇洒哥";
select * from exam_result;


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
4月前
|
SQL 运维 关系型数据库
MySQL 中 GRANT 操作会引起复制中断吗?
GRANT 操作并不是一个原子性操作,不管执行成功与否,都会触发一个隐式重载授权表的行为。 在生产环境中需要规范用户创建及授权的操作,不推荐使用 DML 语句去直接变更 mysql.user 表,可能会引发其他的问题,若使用了 DML 语句进行变更, 需要手工执行 flush privileges。
67 4
|
4月前
|
JavaScript 关系型数据库 MySQL
创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作
创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作
60 0
|
2月前
|
SQL Java 关系型数据库
MySQL数据库基础:增删查改
本文详细介绍了数据库中常用数据类型的使用方法及其在Java中的对应类型,并演示了如何创建表、插入数据、查询数据(包括全列查询、指定列查询、去重查询、排序查询、条件查询和分页查询)、修改数据以及删除数据。此外,还特别强调了处理NULL值时的注意事项,以及在执行修改和删除操作时应谨慎使用条件语句,以避免误操作导致的数据丢失。
74 14
MySQL数据库基础:增删查改
|
29天前
|
存储 关系型数据库 MySQL
【探究Mysql表中的增删查改(进阶篇)】
【探究Mysql表中的增删查改(进阶篇)】
53 7
|
2月前
|
关系型数据库 MySQL 数据库
MySQL 表的CRUD与复合查询
【9月更文挑战第26天】本文介绍了数据库操作中的 CRUD(创建、读取、更新、删除)基本操作及复合查询。创建操作使用 `INSERT INTO` 语句插入数据,支持单条和批量插入;读取操作使用 `SELECT` 语句查询数据,可进行基本查询、条件查询和排序查询;更新操作使用 `UPDATE` 语句修改数据;删除操作使用 `DELETE FROM` 语句删除数据。此外,还介绍了复合查询,包括连接查询(如内连接、左连接)和子查询,以及聚合函数与分组查询,并提供了示例代码。
|
4月前
|
存储 关系型数据库 文件存储
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
47 2
|
4月前
|
SQL 关系型数据库 MySQL
实时计算 Flink版操作报错合集之从mysql读数据写到hive报错,是什么原因
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
3月前
|
前端开发 Java 关系型数据库
通过HTML网页对mysql数据库进行增删改查(CRUD实例)
通过HTML网页对mysql数据库进行增删改查(CRUD实例)
212 0
|
4月前
|
消息中间件 关系型数据库 MySQL
实时计算 Flink版操作报错合集之运行mysql to doris pipeline时报错,该如何排查
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
4月前
|
消息中间件 关系型数据库 MySQL
实时计算 Flink版操作报错合集之整库同步mysql到starRock提交任务异常,该如何处理
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。