当前位置: 首页 > news >正文

【MySQL】增删改查操作 —— CRUD

【MySQL】增删改查操作 —— CRUD

  • 0、前言
  • 一、Create 新增
    • 1.1 语法
    • 1.2 举例
  • 二、Retrieve 检索
    • 2.1 select 查询
      • 2.1.1 全列查询
      • 2.1.2 指定列查询
      • 2.1.3 查询字段为表达式
        • 1. 常量表达式
        • 2. 把所有学生的语文成绩加10分
        • 3. 计算所有学生语文、数学和英语成绩的总分,并指定别名
        • 4. 结果去重查询
    • 2.2 Where 条件查询
      • 2.2.1 语法
      • 2.2.2 比较运算符
      • 2.2.3 逻辑运算符
      • 2.2.4 Where 查询练习
        • 1. 基本查询
        • 2. AND和OR
        • 3. 范围查询
        • 4. 模糊查询
        • 5. NULL的查询
    • 2.3 Order by 排序(对查询出来的结果进行排序)
    • 2.4 分页查询
      • 2.4.1 分页查询 语法
      • 2.4.2 分页查询 实例
        • (1)查看前3条记录
        • (2)按照 id降序查看前2行
        • (3)从0开始,向后查2条记录
        • (4)limit num offset start;
        • (5)当查询条数 大于 数据个数时:
  • 三、Update 修改
    • 3.1 语法
    • 3.2 举例
      • 3.2.1 update exam set math = 80 where name = '孙悟空';
      • 3.2.2 update exam set math = 60,chinese = 70 where name = '曹孟德';
      • 3.2.3 update exam set english = english+10 where name = '唐三藏';
      • 3.2.4 update exam set math = math+30 oder by math+chinese+english asc limit 3;
      • 3.2.5 updata exam set chinese = chinese * 2;
  • 四、Delete 删除
    • 4.1 语法
    • 4.2 举例
      • 4.2.1 delete from exam where name = '孙悟空';
  • 五、截断表 —— 把表恢复到刚创建的状态
    • 5.1 语法
    • 5.2 举例
  • 六、插入查询结果
    • 6.1 语法
    • 6.2 举例
  • 七、聚合函数
    • 7.1 常用函数
    • 7.2 举例
      • 7.2.1 COUNT
      • 7.2.2 SUM
      • 7.2.3 AVG
      • 7.2.4 MAX
      • 7.2.5 MIN
  • 八、Group by 分组查询
    • 8.1 语法
    • 8.2 举例
    • 8.3 having子句
  • 九、内置函数

0、前言

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

一、Create 新增

1.1 语法

insert into table_name [(column [, column] ...)]
VALUES (value_list) [, (value_list)] ...
value_list: value, [, value] ...

在这里插入图片描述

1.2 举例


DROP TABLE exam;-- 创建表结构
CREATE TABLE exam (id BIGINT,name VARCHAR(20) COMMENT '同学姓名',chinese float COMMENT '语文成绩',math float COMMENT '数学成绩',english float COMMENT '英语成绩'
);-- 插入测试数据
INSERT INTO exam (id,name, chinese, math, english) VALUES
(1, '唐三藏', 67, 98, 56),
(2, '孙悟空', 87, 78, 77),
(3, '猪悟能', 88, 98, 90),
(4, '曹孟德', 82, 84, 67),
(5, '刘旋得', 55, 85, 45),
(6, '孙权', 70, 73, 78),
(7, '宋公明', 75, 65, 30);-- 查询
select * from exam;

在这里插入图片描述

二、Retrieve 检索

2.1 select 查询

2.1.1 全列查询

sql select * from 表名; 表示在一个表中查询所有的记录。

举例

DROP TABLE exam;-- 创建表结构
CREATE TABLE exam (id BIGINT,name VARCHAR(20) COMMENT '同学姓名',chinese float COMMENT '语文成绩',math float COMMENT '数学成绩',english float COMMENT '英语成绩'
);-- 插入测试数据
INSERT INTO exam (id,name, chinese, math, english) VALUES
(1, '唐三藏', 67, 98, 56),
(2, '孙悟空', 87, 78, 77),
(3, '猪悟能', 88, 98, 90),
(4, '曹孟德', 82, 84, 67),
(5, '刘旋得', 55, 85, 45),
(6, '孙权', 70, 73, 78),
(7, '宋公明', 75, 65, 30);-- 全列查询
select * from exam;

在这里插入图片描述

2.1.2 指定列查询

-- 指定列查询
select id,name,chinese from exam;

在这里插入图片描述

2.1.3 查询字段为表达式

1. 常量表达式
-- 查询字段为表达式
select id,name,chinese+math+english as sum from exam;

在这里插入图片描述

`

2. 把所有学生的语文成绩加10分
-- 把所有学生的语文成绩加10分
select id,name,chinese,chinese + 10 from exam;

在这里插入图片描述

3. 计算所有学生语文、数学和英语成绩的总分,并指定别名
-- 计算所有学生语文、数学和英语成绩的总分,并指定别名
select id,name,chinese+math+english as total from exam;

在这里插入图片描述

4. 结果去重查询
select math from exam; 

在这里插入图片描述

-- 结果去重查询
select distinct math from exam; 

在这里插入图片描述

注意:
在这里插入图片描述

2.2 Where 条件查询

2.2.1 语法

在这里插入图片描述

2.2.2 比较运算符

在这里插入图片描述举例:

(1)查询字符编码集
在这里插入图片描述

(2)查询 exam表中姓名为孙的信息(模糊查询)

-- 查询 exam表中姓名为孙的信息
select * from exam where name like '孙%';

在这里插入图片描述
(3)查询 exam表中姓名为孙_的信息

select * from exam where name like '孙_';

在这里插入图片描述
(4)查询 exam表中姓名为孙__的信息

select * from exam where name like '孙__';

在这里插入图片描述

2.2.3 逻辑运算符

在这里插入图片描述

2.2.4 Where 查询练习

1. 基本查询

在这里插入图片描述

-- where 查询举例
select name , english from exam where english < 60; 

在这里插入图片描述

在这里插入图片描述

select name, chinese,english from exam where chinese > english;

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

select name,chinese+math+english total from exam where chinese+math+english < 200;

在这里插入图片描述
注意:不可以使用别名在where进行比较!

在这里插入图片描述

2. AND和OR

在这里插入图片描述

select name, chinese, english from exam where chinese > 80 and english > 80;

在这里插入图片描述
在这里插入图片描述

select name, chinese, english from exam where chinese > 80 or english > 80;

在这里插入图片描述

3. 范围查询

在这里插入图片描述

select name,chinese from exam where chinese >=  80 and chinese <= 90;

在这里插入图片描述
或者
在这里插入图片描述

在这里插入图片描述

select name, math from exam where math in (78,79,98,99);

在这里插入图片描述
或者
在这里插入图片描述&&&&&&&&&&&&&&
在这里插入图片描述

4. 模糊查询

在这里插入图片描述

5. NULL的查询
  • 查询值为NULL的数据行
-- 插入张飞的信息
insert into exam values (8,'张飞',27,0,NULL);select * from exam where english is null;

在这里插入图片描述
或者
在这里插入图片描述

  • 查询值不为NULL的数据行
select * from exam where english is not null;

在这里插入图片描述

  • NULL与其他值进⾏运算结果为NULL
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

2.3 Order by 排序(对查询出来的结果进行排序)

  1. 语法
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  2. 举例
    在这里插入图片描述

在这里插入图片描述

select * from exam order by math asc;

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

update exam set math = 98,english = 20,where id = 8;

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
&&&&&&&&&&&&&&&&&&&&&&&
在这里插入图片描述
&&&&&&&&&&&&&&&&&&&&&
在这里插入图片描述

[总结] 在这里插入图片描述

2.4 分页查询

在这里插入图片描述

2.4.1 分页查询 语法

在这里插入图片描述

2.4.2 分页查询 实例

(1)查看前3条记录

在这里插入图片描述

(2)按照 id降序查看前2行

在这里插入图片描述

(3)从0开始,向后查2条记录

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

(4)limit num offset start;

在这里插入图片描述
在这里插入图片描述

(5)当查询条数 大于 数据个数时:

在这里插入图片描述
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
在这里插入图片描述
&&&&&&&&&&&&&&&&&&&&&&&&&&
在这里插入图片描述

三、Update 修改

3.1 语法

在这里插入图片描述

3.2 举例

3.2.1 update exam set math = 80 where name = ‘孙悟空’;

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
注意:
在这里插入图片描述

3.2.2 update exam set math = 60,chinese = 70 where name = ‘曹孟德’;

在这里插入图片描述
在这里插入图片描述
注意:
在这里插入图片描述

3.2.3 update exam set english = english+10 where name = ‘唐三藏’;

在这里插入图片描述
在这里插入图片描述

3.2.4 update exam set math = math+30 oder by math+chinese+english asc limit 3;

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述&&&&&&&&&&&&&&&&&&&&&&&
在这里插入图片描述

3.2.5 updata exam set chinese = chinese * 2;

在这里插入图片描述
在这里插入图片描述

四、Delete 删除

4.1 语法

在这里插入图片描述

4.2 举例

4.2.1 delete from exam where name = ‘孙悟空’;

在这里插入图片描述
在这里插入图片描述
&&&&&&&&&&&&&&&&&&&&&&
在这里插入图片描述

五、截断表 —— 把表恢复到刚创建的状态

5.1 语法

在这里插入图片描述

5.2 举例

在这里插入图片描述
&&&&&&&&&&&&&&&&&
在这里插入图片描述

六、插入查询结果

6.1 语法

在这里插入图片描述

6.2 举例

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

七、聚合函数

7.1 常用函数

在这里插入图片描述

7.2 举例

7.2.1 COUNT

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

7.2.2 SUM

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

7.2.3 AVG

在这里插入图片描述
在这里插入图片描述

7.2.4 MAX

在这里插入图片描述

7.2.5 MIN

在这里插入图片描述
在这里插入图片描述

八、Group by 分组查询

8.1 语法

在这里插入图片描述

在这里插入图片描述

8.2 举例

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
&&&&&&&&&&&&&&&&&&
在这里插入图片描述
在这里插入图片描述

8.3 having子句

在这里插入图片描述
在这里插入图片描述

九、内置函数

http://www.dtcms.com/a/311252.html

相关文章:

  • 楼市低迷能否通过股市提振
  • ADB 底层原理
  • Android 15 中禁用/启用应用的系统级方法
  • 二叉搜索树(C++实现)
  • LeetCode 刷题【26. 删除有序数组中的重复项、27. 移除元素、28. 找出字符串中第一个匹配项的下标】
  • 10.1通用数据类型
  • 查找文献
  • 类似 Pixso 但更侧重「网页 / 软件界面设计」「前后端可视化开发」的工具
  • 【智能体cooragent】_process_workflow 结构拆解分析
  • 一维dp-序列类型-最长有效括号
  • XGBoost三部曲:XGBoost参数详解
  • 机械臂的轨迹生成的多种方案
  • 信号完整性、电源完整性与电磁兼容的含义
  • Removing Digits(Dynamic Programming)
  • SEA-RAFT:更简单、更高效、更准确的RAFT架构
  • 人工智能与交通:智能出行的变革与未来
  • OneCode 3.0表达式从语法到执行的全链路设计
  • 解锁智能油脂润滑系统:加速度与温振传感器选型协同攻略
  • 【隧道篇 / IPsec】(7.6) ❀ 02. 如何删除向导创建的IPsec安全隧道 (点对点) ❀ FortiGate 防火墙
  • 阿里云:Ubuntu系统部署宝塔
  • 【Go语言-Day 29】从time.Now()到Ticker:Go语言time包实战指南
  • eSIM技术深度解析:从物理芯片到数字革命
  • SAP 标准代码测试OO ALV案例分享
  • ubuntu22.04离线一键安装gpu版docker
  • Unity —— Android 应用构建与发布​
  • 社群团购市场选择与开源技术赋能下的下沉市场开拓策略研究——以开源AI智能名片、链动2+1模式与S2B2C商城小程序为例
  • 苹果MAC 安卓模拟器
  • 2561. 重排水果
  • 48Days-Day12 | 添加字符,数组变换,装箱问题
  • 2025牛客暑期多校训练营1(G,E,L,K,I)