MySQL第三章、表的增删查改

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: 新增:-- 单行插入insert into 表(字段1, ..., 字段N) values (value1, ..., value N);-- 多行插入insert into 表(字段1, ..., 字段N) values查询:-- 全列查询select * from 表-- 指定列查询select 字段1,字段2... from 表-- 查询表达式字段select 字段1+100,字段2+字段3 from 表-- 别名select 字段1 别名1, 字段2 别名2 from 表。

 

目录

一、CRUD

二、新增(Create)

2.1单行数据 + 全列插入

2.2多行数据 + 指定列插入

三、查询(Retrieve)

3.1全列查询

3.2指定列查询

3.3 查询字段为表达式

3.4 别名

3.5 去重:DISTINCT

3.6 排序:ORDER BY

3.7 条件查询:WHERE

3.8 分页查询:LIMIT

四、修改(Update)

五、删除(Delete)

六、内容重点总结


一、CRUD

注释:在SQL中可以使用“--空格+描述”来表示注释说明。

CRUD即增加(Create)、查询(Retrieve)、更新(Update)、删除(Delete)四个单词的首字母缩写。


二、新增(Create)

语法:

INSERT [INTO] table_name [(column [, column] ...)]     VALUES (value_list) [, (value_list)] ...     
value_list: value, [, value] ...

image.gif

image.gif编辑案例:

-- 创建一张学生表
DROP TABLE IF EXISTS student;
CREATE TABLE student (
id INT,
sn INT comment '学号',
name VARCHAR(20) comment '姓名',
qq_mail VARCHAR(20) comment 'QQ邮箱'
);

image.gif

image.gif编辑

2.1单行数据 + 全列插入

-- 插入两条记录,value_list 数量必须和定义表的列的数量及顺序一致
INSERT INTO student VALUES (100, 10000, '唐三藏', NULL);
INSERT INTO student VALUES (101, 10001, '孙悟空', '11111');

image.gif

image.gif编辑 2.2多行数据 + 指定列插入

-- 插入两条记录,value_list 数量必须和指定列数量及顺序一致
INSERT INTO student (id, sn, name) VALUES
(102, 20001, '曹孟德'),
(103, 20002, '孙仲谋');

image.gif

image.gif编辑


image.gif编辑


2.3日期的插入

image.gif编辑

三、查询(Retrieve)

语法:

SELECT
[DISTINCT] {* | {column [, column] ...}
[FROM table_name]
[WHERE ...]
[ORDER BY column [ASC | DESC], ...]
LIMIT ...

image.gif

image.gif编辑

案例:

-- 创建考试成绩表
DROP TABLE IF EXISTS exam_result;
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 (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);

image.gif

image.gif编辑 3.1全列查询

-- 通常情况下不建议使用 * 进行全列查询
-- 1. 查询的列越多,意味着需要传输的数据量越大;
-- 2. 可能会影响到索引的使用。(索引待后面课程讲解)
SELECT * FROM exam_result;

image.gif

3.2指定列查询

-- 指定列的顺序不需要按定义表的顺序来
SELECT id, name, english FROM exam_result;

image.gif

image.gif编辑

3.3 查询字段为表达式

-- 表达式不包含字段
SELECT id, name, 10 FROM exam_result;
-- 表达式包含一个字段
SELECT id, name, english + 10 FROM exam_result;
-- 表达式包含多个字段
SELECT id, name, chinese + math + english FROM exam_result;

image.gif

3.4 别名

为查询结果中的列指定别名,表示返回的结果集中,以别名作为该列的名称,语法:

SELECT column [AS] alias_name [...] FROM table_name;
-- 结果集中,表头的列名=别名
SELECT id, name, chinese + math + english 总分 FROM exam_result;

image.gif

image.gif编辑

3.5 去重:DISTINCT

使用DISTINCT关键字对某列数据进行去重:

-- 98 分重复了
SELECT math FROM exam_result;
+--------+
| math |
+--------+
| 98 |
| 78 |
| 98 |
| 84 |
| 85 |
| 73 |
| 65 |
+--------+
7 rows in set (0.00 sec)

image.gif

-- 去重结果
SELECT DISTINCT math FROM exam_result;
+--------+
| math |
+--------+
| 98 |
| 78 |
| 84 |
| 85 |
| 73 |
| 65 |
+--------+
6 rows in set (0.00 sec)

image.gif

image.gif编辑

3.6 排序:ORDER BY

语法:

-- ASC 为升序(从小到大)
-- DESC 为降序(从大到小)
-- 默认为 ASC
SELECT ... FROM table_name [WHERE ...]
ORDER BY column [ASC|DESC], [...];

image.gif

image.gif编辑

1. 没有 ORDER BY 子句的查询,返回的顺序是未定义的,永远不要依赖这个顺序

2. NULL 数据排序,视为比任何值都小,升序出现在最上面,降序出现在最下面

-- 查询同学姓名和 qq_mail,按 qq_mail 排序显示
SELECT name, qq_mail FROM student ORDER BY qq_mail;
SELECT name, qq_mail FROM student ORDER BY qq_mail DESC;

image.gif

3. 使用表达式及别名排序

-- 查询同学及总分,由高到低
SELECT name, chinese + english + math FROM exam_result
ORDER BY chinese + english + math DESC;
SELECT name, chinese + english + math total FROM exam_result
ORDER BY total DESC;

image.gif

4. 可以对多个字段进行排序,排序优先级随书写顺序

-- 查询同学各门成绩,依次按 数学降序,英语升序,语文升序的方式显示
SELECT name, math, english, chinese FROM exam_result
ORDER BY math DESC, english, chinese;

image.gif

3.7 条件查询:WHERE

比较运算符:

image.gif编辑

逻辑运算符:

image.gif编辑 注:
1. WHERE条件可以使用表达式,但不能使用别名。
2. AND的优先级高于OR,在同时使用时,需要使用小括号()包裹优先执行的部分

image.gif编辑

案例:

    • 基本查询:
    -- 查询英语不及格的同学及英语成绩 ( < 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 总分 FROM exam_result
    WHERE chinese + math + english < 200;

    image.gif

    image.gif编辑

      • AND与OR:
      -- 查询语文成绩大于80分,且英语成绩大于80分的同学
      SELECT * FROM exam_result WHERE chinese > 80 and english > 80;
      -- 查询语文成绩大于80分,或英语成绩大于80分的同学
      SELECT * FROM exam_result WHERE chinese > 80 or english > 80;
      -- 观察AND 和 OR 的优先级:
      SELECT * FROM exam_result WHERE chinese > 80 or math>70 and english > 70;
      SELECT * FROM exam_result WHERE (chinese > 80 or math>70) and english > 70;

      image.gif

        • 范围查询:

        1. BETWEEN ... AND ...

        -- 查询语文成绩在 [80, 90] 分的同学及语文成绩
        SELECT name, chinese FROM exam_result WHERE chinese BETWEEN 80 AND 90;
        -- 使用 AND 也可以实现
        SELECT name, chinese FROM exam_result WHERE chinese >= 80 AND chinese
        <= 90;

        image.gif

        2. IN

        -- 查询数学成绩是 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 OR math = 99;

        image.gif

          • 模糊查询:LIKE
          -- % 匹配任意多个(包括 0 个)字符
          SELECT name FROM exam_result WHERE name LIKE '孙%';-- 匹配到孙悟空、孙权
          -- _ 匹配严格的一个任意字符
          SELECT name FROM exam_result WHERE name LIKE '孙_';-- 匹配到孙权

          image.gif

            • NULL 的查询:IS [NOT] NULL
            -- 查询 qq_mail 已知的同学姓名
            SELECT name, qq_mail FROM student WHERE qq_mail IS NOT NULL;
            -- 查询 qq_mail 未知的同学姓名
            SELECT name, qq_mail FROM student WHERE qq_mail IS NULL;

            image.gif

            image.gif编辑

            3.8 分页查询:LIMIT

            语法:

            -- 起始下标为 0
            -- 从 0 开始,筛选 n 条结果
            SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n;
            -- 从 s 开始,筛选 n 条结果
            SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT s, n;
            -- 从 s 开始,筛选 n 条结果,比第二种用法更明确,建议使用
            SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n OFFSET s;

            image.gif

            案例:按 id 进行分页,每页 3 条记录,分别显示 第 1、2、3 页

            -- 第 1 页
            SELECT id, name, math, english, chinese FROM exam_result ORDER BY id LIMIT 3
            OFFSET 0;
            -- 第 2 页
            SELECT id, name, math, english, chinese FROM exam_result ORDER BY id LIMIT 3
            OFFSET 3;
            -- 第 3 页,如果结果不足 3 个,不会有影响
            SELECT id, name, math, english, chinese FROM exam_result ORDER BY id LIMIT 3
            OFFSET 6;

            image.gif

            image.gif编辑image.gif编辑


            四、修改(Update)

            语法:

            UPDATE table_name SET column = expr [, column = expr ...]
            [WHERE ...] [ORDER BY ...] [LIMIT ...]

            image.gif

            案例:

            -- 将孙悟空同学的数学成绩变更为 80 分
            UPDATE exam_result SET math = 80 WHERE name = '孙悟空';
            -- 将曹孟德同学的数学成绩变更为 60 分,语文成绩变更为 70 分
            UPDATE exam_result SET math = 60, chinese = 70 WHERE name = '曹孟德';
            -- 将总成绩倒数前三的 3 位同学的数学成绩加上 30 分
            UPDATE exam_result SET math = math + 30 ORDER BY chinese + math + english LIMIT
            3;
            -- 将所有同学的语文成绩更新为原来的 2 倍
            UPDATE exam_result SET chinese = chinese * 2;

            image.gif

            image.gif编辑image.gif编辑

            image.gif编辑

            网络异常,图片无法展示
            |
            编辑


            五、删除(Delete)

            语法:

            DELETE FROM table_name [WHERE ...] [ORDER BY ...] [LIMIT ...]

            image.gif

            案例:

            -- 删除孙悟空同学的考试成绩
            DELETE FROM exam_result WHERE name = '孙悟空';
            -- 删除整张表数据
            -- 准备测试表
            DROP TABLE IF EXISTS for_delete;
            CREATE TABLE for_delete (
            id INT,
            name VARCHAR(20)
            );
            -- 插入测试数据
            INSERT INTO for_delete (name) VALUES ('A'), ('B'), ('C');
            -- 删除整表数据
            DELETE FROM for_delete;

            image.gif

            image.gif编辑


            六、内容重点总结

              • 新增:
              -- 单行插入
              insert into 表(字段1, ..., 字段N) values (value1, ..., value N);
              -- 多行插入
              insert into 表(字段1, ..., 字段N) values
              (value1, ...),
              (value2, ...),
              (value3, ...);

              image.gif

                • 查询:
                -- 全列查询
                select * from 表
                -- 指定列查询
                select 字段1,字段2... from 表
                -- 查询表达式字段
                select 字段1+100,字段2+字段3 from 表
                -- 别名
                select 字段1 别名1, 字段2 别名2 from 表
                -- 去重DISTINCT
                select distinct 字段 from 表
                -- 排序ORDER BY
                select * from 表 order by 排序字段
                -- 条件查询WHERE:
                -- (1)比较运算符 (2)BETWEEN ... AND ... (3)IN (4)IS NULL (5)LIKE (6)AND (7)OR
                (8)NOT
                select * from 表 where 条件

                image.gif

                  • 修改:
                  update 表 set 字段1=value1, 字段2=value2... where 条件

                  image.gif

                    • 删除:
                    delete from 表 where 条件

                    image.gif

                    相关实践学习
                    如何在云端创建MySQL数据库
                    开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
                    全面了解阿里云能为你做什么
                    阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
                    目录
                    相关文章
                    |
                    2月前
                    |
                    关系型数据库 MySQL 数据库
                    数据迁移脚本优化过程:从 MySQL 到 Django 模型表
                    在大规模的数据迁移过程中,性能问题往往是开发者面临的主要挑战之一。本文将分析一个数据迁移脚本的优化过程,展示如何从 MySQL 数据库迁移数据到 Django 模型表,并探讨优化前后的性能差异。
                    |
                    29天前
                    |
                    存储 SQL 关系型数据库
                    MySQL设计规约问题之在数据库设计中,为什么要适当考虑反范式的表设计
                    MySQL设计规约问题之在数据库设计中,为什么要适当考虑反范式的表设计
                    |
                    29天前
                    |
                    SQL 存储 数据库
                    MySQL设计规约问题之如何处理日志类型的表
                    MySQL设计规约问题之如何处理日志类型的表
                    |
                    1月前
                    |
                    运维 关系型数据库 MySQL
                    实时计算 Flink版产品使用问题之在处理MySQL表新增数据记录时,没有正确触发变更事件,该如何解决
                    实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
                    |
                    2月前
                    |
                    关系型数据库 MySQL
                    蓝易云 - 如何修复MySQL中损坏的表
                    最后,为了防止数据丢失,定期备份数据是非常重要的。
                    131 3
                    |
                    2月前
                    |
                    SQL 关系型数据库 MySQL
                    ClickHouse(23)ClickHouse集成Mysql表引擎详细解析
                    ClickHouse的MySQL引擎允许执行`SELECT`查询从远程MySQL服务器。使用`MySQL(&#39;host:port&#39;, &#39;database&#39;, &#39;table&#39;, &#39;user&#39;, &#39;password&#39;[,...])`格式连接,支持简单`WHERE`子句在MySQL端处理,复杂条件和`LIMIT`在ClickHouse端执行。不支持`NULL`值,用默认值替换。系列文章涵盖ClickHouse安装、集群搭建、表引擎解析等主题。[链接](https://zhangfeidezhu.com/?p=468)有更多
                    104 0
                    |
                    2月前
                    |
                    SQL 缓存 关系型数据库
                    MySQL操作全攻略:库、表、数据、事务全面指南
                    MySQL操作全攻略:库、表、数据、事务全面指南
                    |
                    2月前
                    |
                    SQL 关系型数据库 MySQL
                    经验大分享:MySQL(三)数据库表的查询操作【重要】
                    经验大分享:MySQL(三)数据库表的查询操作【重要】
                    35 0
                    |
                    2月前
                    |
                    存储 SQL 关系型数据库
                    【MySQL技术内幕】4.1-索引组织表
                    【MySQL技术内幕】4.1-索引组织表
                    23 0
                    |
                    2月前
                    |
                    分布式计算 DataWorks MaxCompute
                    DataWorks产品使用合集之新创建的工作空间,任务提交了,但是周期实例里面没任何数据,是什么导致的
                    DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。