MySQL 表的增删查改(CRUD)

news2025/1/16 1:38:20

MySQL 表的增删查改(CRUD)

文章目录

  • MySQL 表的增删查改(CRUD)
    • 1. 新增(Create)
    • 2. 查询(Retrieve)
      • 2.1 全列查询
      • 2.2 指定列查询
      • 2.3 查询字段为表达式
      • 2.4 别名
      • 2.5 去重:DISTINCT
      • 2.6 排序:ORDER BY
      • 2.7 条件查询
      • 2.8 分页查询: LIMIT
    • 3. 修改(Update)
    • 4. 删除(Delete)

在这篇文章中我们将对MySQL表的CRUD进行讲解

CRUD 即增加(create)、查询(Retrieve)、更新(Update)、删除(Delete)

1. 新增(Create)

语法:

INSERT INTO table_name [指定列名] VALUES (value_list, value_list1...);

在这里我们先创建一张学生表:

 create table student_test (
     id int,
     sn int comment '学号',
     name varchar(20) comment '姓名',
     qq_mail varchar(20) comment 'QQ邮箱');

在这里插入图片描述

操作:

  • 单行数据 + 全列插入

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

    在这里插入图片描述

  • 多行数据 + 指定列插入

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

    在这里插入图片描述

2. 查询(Retrieve)

注:查询的所有操作都不会对数据库硬盘上存储的数据进行修改,都是针对临时表展开的操作

语法:

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

这里我们先创建一张考试成绩表并填入数据:

mysql> create table exam_result (
     id int,
     name varchar(30),
     chinese decimal(4, 1),
     math decimal (4, 1),
     english decimal (4, 1));

mysql> insert into exam_result (id, name ,chinese, math, english) values
     (1, '唐三藏', 67, 98, 56),
     (2, '孙悟空', 87.5, 99, 77),
     (3, '猪悟能', 80, 78.5, 90),
     (4, '曹孟德', 97, 80, 75),
     (5, '刘玄德', 85, 87, 88),
     (6, '孙仲谋', 75, 80, 95),
     (7, '诸葛孔明', 99, 100, 98);

在这里插入图片描述

2.1 全列查询

-- 通常情况下不建议使用 * 进行全列查询
-- 1. 查询的列越多,意味着需要传输的数据量越大;
-- 2. 可能会影响导索引的使用
SELECT * FROM exam_result;

在这里插入图片描述

2.2 指定列查询

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

在这里插入图片描述

2.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;

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

2.4 别名

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

语法:

SELECT column [AS] alias_name [...] FROM table_name;
-- 结果集中,表头的列名 = 别名 (as建议加上)
SELECT id, name, chinese + math + english as total FROM exam_result;

在这里插入图片描述

2.5 去重:DISTINCT

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

SELECT DISTINCT math from exam_result;

在这里插入图片描述

2.6 排序:ORDER BY

语法:

-- ASC 为升序 (从小到大) -- 默认为ASC
-- DESC 为降序 (从大到小)
SELECT ... FROM table_name ORDER BY column [ASC|DESC], [...];
  1. 没有ORDER BY 子句的查询,返回的顺序是未定义的,不要依赖这个顺序

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

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

    在这里插入图片描述

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

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

    在这里插入图片描述

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

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

    在这里插入图片描述

2.7 条件查询

比较运算符:

算符说明
>, >=, <, <=大于,大于等于,小于,小于等于
=等于,NULL 不安全,例如 NULL = NULL 的结果是 NULL
<=>等于,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
LIKE模糊匹配。% 表示任意多个(包括 0 个)任意字符;_ 表示任意一个字 符

逻辑运算符:

运算符说明
AND多个条件必须都为 TRUE(1),结果才是 TRUE(1)
OR任意一个条件为 TRUE(1), 结果为 TRUE(1)
NOT条件为 TRUE(1),结果为 FALSE(0)

注:

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

操作:

  • 基本查询

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

    在这里插入图片描述

    注:这里如果使用别名来进行判断会报错:

    在这里插入图片描述

  • 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 WHEARE (chinese > 80 or math > 70) and english > 70;
    

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    and的优先级高于or

  • 范围查询

    1. BETWEEN … AND …

      -- 查询语文成绩在 [80,90] 分的同学及语文成绩
      SELECT name, chinese FROM exam_result WHERE chinese BETWEEN 80 AND 90;
      

      在这里插入图片描述

      :此时的范围为闭区间

    2. IN

      -- 查询数学成绩是 58 或 59 或 98 或 99分的同学及数学成绩
      SELECT name, math FROM exam_result WHERE math IN (58, 59, 98, 99);
      

      在这里插入图片描述

  • 模糊查询: LIKE

    这里需要使用到两个符号:通配符%_

    • % :匹配任意个字符

    • _ :只能匹配一个字符

    在这里先插入一些数据:

    在这里插入图片描述

    % 操作:

    -- 匹配名字中以孙开头的同学
    SELECT * FROM exam_result WHERE name like '孙%';
    
    -- 匹配名字中以孙结尾的同学
    SELECT * FROM exam_result WHERE name like '%孙';
    
    -- 匹配名字中包含孙的同学
    SELECT * FROM exam_result WHERE name like '%孙%';
    

    在这里插入图片描述

    注: %也可以表示匹配到0个字符

    _ 操作:

    -- 匹配名字中以孙开头的同学
    SELECT * FROM exam_result WHERE name like '孙_'; // 此处为空
    SELECT * FROM exam_result WHERE name like '孙__';
    

    在这里插入图片描述

  • 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;
    

    在这里插入图片描述

2.8 分页查询: LIMIT

limit: 限制这次请求返回多少个记录(一页里有几条数据)

offset: 描述当前结果从第几条开始获取,不写offse 为默认情况 (从第 0 条开始)

语法:

-- 起始下标为0
-- 从 0 开始,筛选 n 条结果 (返回n条数据)
SELECT ... FROM table_name [WHERE ...][ORDER BY] LIMIT n;
-- 从 s 开始, 筛选 n 条结果
SELECT ... FROM table_name [WHERE ...][ORDER BY] LIMIT n OFFSET s;

案例:按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 页
SELECT id, name, math, english, chinese FROM exam_result ORDER BY id LIMIT 3 OFFSET 6;

在这里插入图片描述

3. 修改(Update)

语法:

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

update 表名 set 列名 (此处可以修改多个列)= 值 where 条件 (如果条件不写,就是针对所有的行进行修改)

注:进行修改时,要定位到行和列,再修改值

案例:

-- 将孙悟空的数学成绩变更为 85 分
UPDATE exam_result SET math = 85 WHERE name = '孙悟空';

-- 将曹孟德 的数学变成90分,语文变成85分
UPDATE exam_result SET math = 90, chinese = 85 where name = '曹孟德';

-- 将总成绩前三的 3 位同学的数学成绩减 10 分
UPDATE exam_result set math = math - 10 ORDER BY chinese + math + english DESC LIMIT 3;

-- 将所有同学的语文成绩更新为原来的 2 倍
UPDATE exam_result SET chinese = chinese * 2;

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

4. 删除(Delete)

语法:

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

案例:

-- 删除孙行者的考试成绩
DELETE FROM exam_result WHERE name = '孙行者';

在这里插入图片描述

在这里插入图片描述

-- 删除整张表
-- 准备测试表
CREATE TABLE for_delete (id INT, name VARCHAR(20));
-- 插入测试数据
INSERT INTO for_delete (name) values ('A'), ('B'), ('C');
--删除整表数据
DELETE FROM for_delete;

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1172564.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Springboot3整合Mybatis-plus3.5.3报错

✅作者简介&#xff1a;大家好&#xff0c;我是Leo&#xff0c;热爱Java后端开发者&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;Leo的博客 &#x1f49e;当前专栏&#xff1a; 报错以及Bug ✨特色专栏&#xff1a; …

QT在线安装所有版本,可共存(下载速度飞快)

使用最新的QT在线安装器&#xff0c;安装QT版本时只能安装5.15以及之后的版本&#xff0c;安装QT5.15之前的版本只能通过离线安装的方式&#xff0c;离线安装后还要自己去配置QT&#xff0c;离线安装还有个问题的&#xff0c;后续维护比较麻烦&#xff0c;QT的维护工具还要自己…

ubuntu中如何设置中文输入

文章目录 1.找到设置&#xff08;settings&#xff09;2.找到keyboard3.点击Chinese&#xff0c;选择intelligent pinyin&#xff0c;并点击add4.打开浏览器测试一下 1.找到设置&#xff08;settings&#xff09; 2.找到keyboard 3.点击Chinese&#xff0c;选择intelligent pin…

1+2+4+7+11+16+..x(和不超过3000),求x与式子的和

我们不难发现&#xff1a;每一项的差值成等差数列 用一个for循环&#xff0c;再用一个变量n存储等差数列 for(int i0;i<300;iin) {sumsumi;n; } 完整代码&#xff1a; #include <stdio.h> int main() {int sum 0;int i 0;int n 0;for (i 1;i < 300;i i n){…

如何在React项目中,创建令人惊叹的动画翻转卡片效果

翻转卡片是一种在网站上展示内容的动态而引人入胜的方法。翻转卡片由正面和背面两个面构成。用户可以通过点击或鼠标悬停来翻转卡片以显示更多信息。本文将向您展示如何在React中轻松构建翻转卡片。 为什么翻转卡片是您网站的有价值的补充&#xff1f; 翻转卡片可以为您的网站用…

系列五、过滤器(一)#概述

一、概述 过滤器的作用是对客户端发送给Servlet的请求以及Servlet返回给客户端的响应做一些定制化的处理&#xff0c;例如&#xff1a; &#xff08;1&#xff09;校验请求的参数是否符合逻辑&#xff0c;符合逻辑则放行&#xff0c;不符合逻辑则不允许访问方法 &#xff08;2&…

顺序栈练习

顺序栈练习 相关内容&#xff1a; 1.判断顺序栈栈满的两种方式 2.一张图理解栈顶指针加加减减的问题 3.栈的顺序存储结构&#xff08;顺序栈&#xff09; //顺序栈的初始化、判空、入栈、出栈、读取栈顶元素 //顺序栈的结构&#xff1a;数组、栈顶指针(本质是下标) #include&…

大数据毕业设计选题推荐-旅游景点游客数据分析-Hadoop-Spark-Hive

✨作者主页&#xff1a;IT毕设梦工厂✨ 个人简介&#xff1a;曾从事计算机专业培训教学&#xff0c;擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Py…

使用脚手架创建项目,使用组件开发

单文件组件 单文件组件就是一个文件对应一个组件, 单文件组件的名字通常是xxx.vue(命名规范和组件名的命名规范相同),这个文件是Vue框架规定的只有它能够认识&#xff0c;浏览器无法直接打开运行 Vue框架可以将xxx.vue文件进行编译为浏览器能识别的html js css的代码 xxx.vu…

【Python基础知识一】基本语法、常用数据类型等

Python基础知识&#xff1a; 1 标识符&#xff08;Identifier&#xff09;2 关键字/保留字&#xff08;Keyword&#xff09;3 引号4 编码5 输入输出6 行与缩进7 多行语句8 注释9 数据类型9.1 数字(Number)类型9.2 变量&#xff08;variate&#xff09;9.3 字符串&#xff08;St…

【漏洞复现】Apache_HTTPD_多后缀解析漏洞

感谢互联网提供分享知识与智慧&#xff0c;在法治的社会里&#xff0c;请遵守有关法律法规 文章目录 1.1、漏洞描述1.2、漏洞复现1、基础环境2、漏洞验证 1.3、深度利用GetShell 1.4、修复建议 1.1、漏洞描述 Apache HTTPD 支持一个文件拥有多个后缀&#xff0c;并为不同后缀执…

你了解SonarQube 吗

你了解SonarQube 吗 文章目录 你了解SonarQube 吗一、介绍二、idea代码检测工具SonarLint安装方法使用方法 三、常见的Sonar解决方法Unused "private" fields should be removedSections of code should not be "commented out"Useless imports should be …

异星工场入门笔记-02-一个重要地学习方法

编程学习地整个过程&#xff0c;最重要的工具就是电脑&#xff0c;其中有一个重点就是可以无成本的重复测试&#xff0c;这大大降低了难度&#xff0c;节约了时间。真正难以学习的不是技术本身&#xff0c;而是材料成本和时间成本&#xff0c;降低这两个因素平地起高楼根本不是…

go语言 | grpc原理介绍(二)

gRPC gRPC 是一个高性能、通用的开源 RPC 框架&#xff0c;其由 Google 2015 年主要面向移动应用开发并基于 HTTP/2 协议标准而设计&#xff0c;基于 ProtoBuf 序列化协议开发&#xff0c;且支持众多开发语言。 由于是开源框架&#xff0c;通信的双方可以进行二次开发&#x…

Canoe UDS诊断技术

Canoe UDS诊断 汽车诊断技术概述诊断术语OBD诊断CAN诊断协议诊断周期UDS诊断服务Diagnostic Request和Response诊断服务介绍 诊断文件CDD介绍诊断安全访问服务(security Access)介绍 如何在Canoe UDS诊断实战CANoe 开启诊断功能Canoe 诊断实战 汽车诊断技术概述 汽车诊断技术是…

让SOME/IP运转起来——SOME/IP系统设计(上)

什么是SOME/IP&#xff1f; SOME/IP&#xff08;Scalable service-Oriented MiddlewarE over IP&#xff09;是AUTOSAR应用层的协议&#xff0c;是基于IP协议的面向服务的可拓展性的中间件。 SOME/IP中主要定义了&#xff1a; 数据的序列化&#xff1a;SOME/IP支持的数据类型…

DirectX3D 虚拟现实项目 三维物体的光照及着色(五个不同着色效果的旋转茶壶)

文章目录 任务要求原始代码CPP文件代码着色器文件代码 效果展示 任务要求 本篇文章是中国农业大学虚拟现实课程的一次作业内容&#xff0c;需要对五个茶壶模型使用不同的光照进行着色和渲染&#xff0c;然后旋转展示。 本人的代码也是在其他人的代码的基础上修改来的&#xf…

学习网络安全有哪些误区?学习之前要做哪些准备?如何系统的学习黑客技术/网络安全?

如果你想学习网络安全&#xff0c;首先你必须了解什么是网络安全&#xff01;什么是黑客&#xff01; 1.无论网络、Web、移动、桌面、云等哪个领域&#xff0c;都有攻与防两面性&#xff0c;例如 Web 安全技术&#xff0c;既有 Web 渗透2.也有 Web 防御技术&#xff08;WAF&am…

CVE-2023-34040 Kafka 反序列化RCE

漏洞描述 Spring Kafka 是 Spring Framework 生态系统中的一个模块&#xff0c;用于简化在 Spring 应用程序中集成 Apache Kafka 的过程&#xff0c;记录 (record) 指 Kafka 消息中的一条记录。 受影响版本中默认未对记录配置 ErrorHandlingDeserializer&#xff0c;当用户将容…

MATLAB 绘制 SISO 和 MIMO 线性系统的时间和频率响应图

系列文章目录 文章目录 系列文章目录前言一、时间响应二、频率响应三、极点/零点图和根节点四、响应特性五、分析 MIMO 系统六、系统比较七、修改时间轴或频率轴数值如果觉得内容不错&#xff0c;请点赞、收藏、关注 前言 本例演示如何绘制 SISO 和 MIMO 线性系统的时间和频率…