【MySQL】数据操作语句(DML)

在这里插入图片描述

👦个人主页:@Weraphael
✍🏻作者简介:目前学习计网、mysql和算法
✈️专栏:MySQL学习
🐋 希望大家多多支持,咱一起进步!😁
如果文章对你有帮助的话
欢迎 评论💬 点赞👍🏻 收藏 📂 加关注✨


目录

  • 一、增
      • 1.1 insert
      • 1.2 插入或更新
      • 1.3 replace
      • 1.4 将查询结果插入到指定的表中
  • 二、查
      • 2.1 select
      • 2.2 全列查询 + 指定列查询
      • 2.3 查询字段为表达式
      • 2.4 去重
      • 2.5 where子句(过滤筛选)
      • 2.6 排序order by
      • 2.7 筛选分页结果limit
  • 三、改
      • 3.1 update
      • 3.2 案例1:将孙悟空的数学成绩变更为 80 分
      • 3:3 案例2:将曹孟德的数学成绩变更为 60 分,语文成绩变更为 70 分
      • 3.4 案例3:将总成绩倒数前三的 3 位同学的数学成绩加上 30 分
      • 3.5 案例4:将所有同学的语文成绩更新为原来的 2 倍
  • 四、删
      • 4.1 delete
      • 4.2 截断表truncate
      • 4.3 案例1:删除孙悟空同学的考试成绩
      • 4.4 案例2:删除总分是倒数第一的同学
  • 五、补充:where子句案例
      • 5.1 英语成绩<60的同学及英语成绩
      • 5.2 语文成绩在 [80, 90] 分的同学及语文成绩
      • 5.3 数学成绩是58或者59或者98或者99分的同学及数学成绩
      • 5.4 姓孙的同学及孙某同学(模糊匹配)
      • 5.5 语文成绩好于英语成绩的同学
      • 5.6 总分在 200 分以下的同学(执行顺序问题)
      • 5.7 语文成绩 > 80 并且不姓孙的同学
      • 5.8 筛选出孙某同学,否则要求总成绩 > 200 并且 语文成绩 < 数学成绩 并且 英语成绩 > 80
  • 六、补充:order by子句案例
      • 6.1 同学及数学成绩,按数学成绩升序显示
      • 6.2 同学及英语成绩,按英语成绩升序排序
      • 6.3 查询同学各门成绩,依次按 数学降序,英语升序,语文升序的方式显示
      • 6.4 查询同学及总分,由高到低
      • 6.5 查询姓孙的同学或者姓曹的同学数学成绩,结果按数学成绩由高到低显示

一、增

1.1 insert

【语法】

insert into 表名 (字段1, 字段2, ...) values (1,2, ...);
  • 插入数据时要确保插入的数据类型格式正确,符合表定义的约束条件(如主键、唯一性约束、非空约束等),以避免出现错误。

  • 可以省略into

  • 可以省略(字段1, 字段2, ...),如果将列名部分全部省略,默认是全列插入;当然也可以指定列名插入。

  • 支持批量插入。

insert into 表名 (字段1, 字段2, ...) values (1,2, ...), (1,2, ...), ...;

【使用案例】

  • 单行数据 + 全列插入

在这里插入图片描述

  • 多行数据 + 指定列插入

在这里插入图片描述

1.2 插入或更新

由于主键或者唯一键对应的值已经存在,那么一定会导致插入失败

在这里插入图片描述

在这种情况下,可以选择性的进行同步更新操作

语法如下:

insert into 表名 (字段1,...) values (1,...) on duplicate key update1 =1,2 =2,3 =3, ...;

如果表中已经存在相同的唯一键或主键,则会更新已存在的记录;如果不存在,则会插入新记录。

【使用案例】

假设有一个名为 users的表,其中id列是主键,name列是唯一键,要插入一条数据,如果已存在相同的name,则更新对应的age,如果不存在,则插入新记录,可以这样写:

在这里插入图片描述

那么问题来了,我们怎么知道是执行了插入操作还是更新操作?

方法一:可以通过MySQL数据库返回的信息来判断

-- 0 row affected: 表中有冲突数据,更新的内容还是和表中原有的数据冲突
-- 1 row affected: 表中没有冲突数据,数据被插入
-- 2 row affected: 表中有冲突数据,并且数据已经被更新

方法二:通过MySQL函数获取受到影响的数据行数

select row_count();

1.3 replace

替换其实类似于insert into ... on duplicate key update,但是在某些情况下具有不同的行为。具体来说,替换会尝试插入一条新记录,如果表中已存在与新记录具有相同唯一键或主键的记录,则会删除已存在的记录,然后插入新记录,是一种比较暴力的做法。

基本语法如下:

replace into 表名 (1,2, ...) values (1,2, ...);

【使用案例】

假设有一个名为 users的表,其中id列是主键,name列是唯一键,要插入一条数据,如果已存在相同的主键或唯一键,则替换已存在的记录,可以这样写:

在这里插入图片描述

1.4 将查询结果插入到指定的表中

insert into 表名 [指定列] select ...
  • [指定列]是可选项,指定要插入数据的目标表的列名。如果省略了列名,则默认假定插入的数据顺序与表中列的顺序相同。
  • select ...: 指定要插入的数据来源。这个select查询语句将返回一组数据,这些数据将会被插入到目标表中。

举例来说,假设有一个名为target_table的表,具有列col1col2col3,并且表数据如下:

在这里插入图片描述

然后新建一个名为nums表结构(结果需要和target_table 一样)

在这里插入图片描述

最后将target_table中所有的数据插入到nums

在这里插入图片描述

二、查

2.1 select

select是用于从数据库中检索数据的关键字,是SQL最常用的语句之一。通过select语句,你可以从一个或多个表中检索出符合特定条件的数据,并根据需要对数据进行排序分组等操作。

【语法】

select distinct1,2,... from 表名 where 条件 order by 列名 limit 行数;
  • distinct可以对表中重复的数据去重

  • 列1, 列2, ... 是要检索的列的列表;如果需要检索所有列,则可以使用通配符 *

  • where 子句用于指定检索数据的条件,可以根据需求添加,当然也可以省略。

  • order by 子句用于对检索出的数据进行排序。

  • limit 子句用于限制检索出的数据行数,可以指定从检索结果的开头返回的行数,也可以指定起始位置和行数。

接下来一一介绍select的一些重要功能。已知表的结构以及数据如下所示:

在这里插入图片描述

2.2 全列查询 + 指定列查询

全列查询是指使用通配符*来检索表中的所有列数据

select * from 表名; 

在这里插入图片描述

往后不建议使用*进行全列查询。因为查询的列越多,意味着需要传输的数据量越大。同时可能会影响到索引的使用(遍历)。

因此我们可以使用指定列查询:指定列的顺序可以不用按定义表的顺序来

select1,2, ... from 表名;

在这里插入图片描述

2.3 查询字段为表达式

  • select可以计算表达式。
    在这里插入图片描述

假设需要计算出chinesemathenglish三科加起来的总成绩:

在这里插入图片描述

我们也可以通过 别名(as关键字) 来指定返回的字段名。这样可以方便地在查询结果中使用计算后的值,并且不会影响原始数据。注意:as也可以省略不写。

在这里插入图片描述

2.4 去重

使用distinct关键字。这会删除结果集中重复的行,只保留唯一的行。

select distinct 指定列 from 列名;

在这里插入图片描述

在以上表的数据中,数学成绩存在重复,因此可以使用去重查询

在这里插入图片描述

2.5 where子句(过滤筛选)

where其实相当于C/C++中的if

  • 比较运算符
运算符说明
>, >=, <, <=大于,大于等于,小于,小于等于
=等于。不能用此运算符来判断是否等于NULL
<=>等于。专门用来判断是否等于NULL(建议用 is null
!=不等于。不能用此运算符来判断是否不等于null,建议使用is not null
<>不等于。不能用此运算符来判断是否不等于null,建议使用is not null
between a0 and a1范围匹配[a0, a1],如果a0 <= value <= a1,返回1(true)
in (option, ...)如果是option中的任意一个,返回1(true)
is nullnull
is not null不是null
like模糊匹配%表示任意多个(包括 0 个)任意字符;_表示任意一个字符
  • 逻辑运算符
运算符说明
and相当于C/C++中的&&
or相当于C/C++中的或
not相当于C/C++中的!

大家看完这几道题,就能很好掌握where子句了。点击跳转

2.6 排序order by

MySQL中,可以使用order by子句对查询结果进行排序。order by子句允许你按照一个或多个列的值对结果进行排序,可以按照升序(从小到大)或者降序(从大到小)的顺序进行排序。

select 列名 from 表名 order by1 [ASC/DESC],2 [ASC/DESC], ...;
# -- ASC 为升序(从小到大)
# -- DESC 为降序(从大到小)
# -- 默认为升序ASC

大家看完这几道题,就能很好掌握order by了。点击跳转

2.7 筛选分页结果limit

MySQL中,当一个表的数据非常大的时候,按照以上方法会导致查询出来的效果不太明显,你可以使用limit子句来实现分页功能

建议:对未知表进行查询时,最好加一条 limit 1,避免因为表中数据过大,查询全表数据导致数据库卡死

  • 写法一:读取表中的前n
select * from 列表 limit n;

在这里插入图片描述

  • 写法二:从某行row开始读取n
select * from 列表 limit row, n;
# row - 开始位置(下标从0开始,0表示第一条记录)
# n - 步长。从开始位置开始,连续读取多少条记录

在这里插入图片描述

  • 写法三:和写法二类似
select * from 列表 limit n, offset row;
# row - 起始位置
# n - 步长

在这里插入图片描述

三、改

3.1 update

mysql中,可以使用update语句对查询到的结果进行列值更新(修改)。

【语法】

update 表名 set column1 = value1, column2 = value2, ... [where condition] [order by] [limit];

解释一下各个部分的含义:

  • set 用于指定要更新的列column和它们的新值value
  • column1, column2, ... 要更新的列的名称。
  • value1, value2, ... 要将相应列设置为的新值。
  • where 可选项,用于指定筛选条件,只有满足条件的记录才会被更新如果省略where子句,则所有记录都将被更新。
  • order by 可选项
  • limit 可选项

3.2 案例1:将孙悟空的数学成绩变更为 80 分

update exam_result set math=80 where name='孙悟空';

在这里插入图片描述

3:3 案例2:将曹孟德的数学成绩变更为 60 分,语文成绩变更为 70 分

update exam_result set math=60,chinese=70 where name='曹孟德';

在这里插入图片描述

3.4 案例3:将总成绩倒数前三的 3 位同学的数学成绩加上 30 分

update exam_result set math=math+30 order by chinese+math+english asc limit 3;

注意:mysql不支持math += 30这种语法

在这里插入图片描述

3.5 案例4:将所有同学的语文成绩更新为原来的 2 倍

select name,chinese from exam_result;

在这里插入图片描述

四、删

4.1 delete

delete语句用于从表中删除记录。它可以根据指定的条件删除一行或多行数据。

delete from 表名 [where condition] [order by] [limit];
# 如果省略where子句,表中的所有数据将会被删除
# 不省略,则仅在满足条件的记录才会被删除。
# 注意:delete只会删除数据,不会删除表结构

请注意,删除操作是不可逆的,因此在执行delete语句之前,请务必谨慎考虑并确保您真正希望删除这些记录。

4.2 截断表truncate

truncatedelete一样都是用于从表中删除数据的SQL命令

truncate [table] 表名

但它们之间有一些重要的区别:

  • 只能对整表操作,不能像delete一样针对部分数据操作。
  • truncate会重置auto_increment项,而delete不会。
  • truncate在删除数据的时候,并不经过事务,也就是说它不会将操作记录保存在日志文件中,同时也使得truncate操作更加快速。

4.3 案例1:删除孙悟空同学的考试成绩

delete from exam_result where name='孙悟空';

在这里插入图片描述

4.4 案例2:删除总分是倒数第一的同学

delete from exam_result order by chinese+english+math asc limit 1;

在这里插入图片描述

五、补充:where子句案例

5.1 英语成绩<60的同学及英语成绩

select name 姓名, english 英语成绩 from exam_result where english<60;

在这里插入图片描述

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

select name 姓名,chinese 语文成绩 from exam_result where chinese >= 80 and chinese <= 90;

在这里插入图片描述

但是以上代码不够优雅,对于这种范围匹配,还可以用between and

select name 姓名,chinese 语文成绩 from exam_result where chinese between 80 and 90;

在这里插入图片描述

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

select name,math from exam_result where math=58 or math=59 or math=98 or math=99;

在这里插入图片描述

但是以上代码不够优雅,在mysql中,可以使用 in操作符来检查某个表达式是否在一个列表中的多个值之中。当某个表达式的值与列表中的任何一个值匹配时,in操作符将返回1true),否则返回0false)。

select name,math from exam_result where math in (58,59,98,99);

在这里插入图片描述

5.4 姓孙的同学及孙某同学(模糊匹配)

这道题考察的是模糊匹配like

  • 姓孙的同学:可能叫,可能叫孙某,可能叫孙某某 …,因此要用 %来表示任意字符
select name from exam_result where name like '孙%';

在这里插入图片描述

  • 孙某同学:则需要使用 _表示任意一个字符
select name from exam_result where name like '孙_';

在这里插入图片描述

5.5 语文成绩好于英语成绩的同学

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

在这里插入图片描述

5.6 总分在 200 分以下的同学(执行顺序问题)

select name 姓名,chinese+math+english 总分 from exam_result where chinese+math+english<200;

在这里插入图片描述

这里有一个问题:where子句后面的表达式chinese+math+english太长了,而前面我们将其重命名为总分,所以直接简写成总分<200即可。

在这里插入图片描述

mysql直接报错了error,这里其实涉及 mysql的执行顺序问题

在这里插入图片描述

总结:别名不能用在where条件中使用

5.7 语文成绩 > 80 并且不姓孙的同学

select name,chinese from exam_result where chinese>80 and name not like '孙%';

在这里插入图片描述

5.8 筛选出孙某同学,否则要求总成绩 > 200 并且 语文成绩 < 数学成绩 并且 英语成绩 > 80

select name,chinese,math,english from exam_result where name like '孙_' or chinese+math+english>200 and chinese<math and english > 80;

在这里插入图片描述

六、补充:order by子句案例

6.1 同学及数学成绩,按数学成绩升序显示

select name,math from exam_result order by math asc;

在这里插入图片描述

6.2 同学及英语成绩,按英语成绩升序排序

select name,english from exam_result order by english asc;

在这里插入图片描述

需要注意的是:null视为比任何值都小。

6.3 查询同学各门成绩,依次按 数学降序,英语升序,语文升序的方式显示

这将按照数学成绩降序排列,然后在数学成绩相同的情况下按照英语成绩升序排列,最后在数学和英语成绩都相同时按照语文成绩升序排列。

select name,math,english,chinese from exam_result order by math desc,english asc,chinese asc;

在这里插入图片描述

6.4 查询同学及总分,由高到低

  • order by子句中可以使用表达式
select name,chinese+math+english from exam_result order by chinese+math+english desc;

在这里插入图片描述

  • order by子句中可以使用列别名
select name,chinese+math+english 总分 from exam_result order by 总分 desc;

在这里插入图片描述

为什么这里就可以使用别名了,而where子句后面不能使用别名?同样可以一起再来分析执行顺序:

在这里插入图片描述

总之,order by子句是在整个过程中最后执行的语句。

6.5 查询姓孙的同学或者姓曹的同学数学成绩,结果按数学成绩由高到低显示

select name,math from exam_result where name like '孙%' or name like '曹%' order by math desc;

在这里插入图片描述

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

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

相关文章

【论文通读】AgentStudio: A Toolkit for Building General Virtual Agents

AgentStudio: A Toolkit for Building General Virtual Agents 前言AbstractMotivationFramework评估GUI GroudingReal-World Cross-Application Benchmark Suite Conclusion 前言 来自昆仑万象的一篇智能体环境数据大一统框架工作&#xff0c;对未来计算机智能体的发展具有指…

FPGA常用IP核之FIFO学习

IP核是FPGA芯片公司提供的逻辑功能块&#xff0c;在FPGA芯片中可以进行优化和预先配置&#xff0c;可以直接在用户设计的程序中使用&#xff0c;应用范围很广。在FPGA设计开发过程中使用IP核&#xff0c;可以大大的缩短开发周期&#xff0c;高度优化的IP核可以使FPG开发工程师专…

前端三剑客 —— CSS (第六节)

目录 内容回顾&#xff1a; 弹性布局属性介绍 案例演示 商品案例 布局分析 登录案例 网格布局 内容回顾&#xff1a; 变量&#xff1a;定义变量使用 --名称&#xff1a;值&#xff1b; 使用变量&#xff1a; 属性名&#xff1a;var&#xff08;--名称&#xff09;&a…

虚拟主机、VPS主机和云服务器的区别

对于每个建站新手来说&#xff0c;首先要解决的就是服务器购买的问题&#xff0c;目前市面有很多类型的服务器&#xff0c;常见的有&#xff1a;阿里云、腾讯云、Vultr云服务器&#xff0c;也有RackNerd、Cloudways等提供的VPS&#xff0c;还有SiteGround、ChemiCloud 、 Hosti…

数据结构之堆底层实现的循序渐进

题外话 把没写的都补回来! 正题 堆 概念 堆是一棵完全二叉树&#xff0c;因此可以层序的规则采用顺序的方式来高效存储&#xff0c; 大根堆:指根结点比左右孩子都大的堆 小根堆:指根结点比左右孩子都小的堆 性质 1.堆中某个节点的值总是不大于或不小于其父节点的值 2…

鸿蒙OS元服务开发:【(Stage模型)设置应用主窗口】

一、设置应用主窗口说明 在Stage模型下&#xff0c;应用主窗口由UIAbility创建并维护生命周期。在UIAbility的onWindowStageCreate回调中&#xff0c;通过WindowStage获取应用主窗口&#xff0c;即可对其进行属性设置等操作。还可以在应用配置文件中设置应用主窗口的属性&…

每日一题(leetcode1026):节点与其祖先的最大差值--dfs

考虑到只能计算祖先之间的节点差而不能计算兄弟之间的节点差&#xff0c;所以思考使用dfs来解决该题。 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), ri…

嵌入式开发学习---(部分)数据结构(无代码)

数据结构 为什么学习数据结构&#xff1f; 1&#xff09;c语言告诉如何写程序&#xff0c;数据结构是如何简洁高效的写程序 2&#xff09;遇到一个实际问题&#xff0c;需要写程序去实现相应功能&#xff0c;需要解决那两个方面的问题&#xff1f; 如何表达数据之间的逻辑规律…

背包问题---

一、背包模型 有一个体积为V的背包,商店有n个物品,每个物品有一个价值v和体积w,每个物品只能被拿一次,问能够装下物品的最大价值。 这里每一种物品只有两种状态即"拿"或"不拿". 设状态dp[i][j]表示到第i个物品为止,拿的物品总体积为j的情况下的最大价…

一、持续集成介绍

持续集成介绍 一、什么是持续集成二、持续集成的流程三、持续集成的组成要素四、持续集成的好处 一、什么是持续集成 持续集成&#xff08;CI&#xff09;指的是&#xff0c;频繁地&#xff08;一天多次&#xff09;将代码集成到主干。持续集成的目的&#xff0c;就是让产品可…

LeetCode:1483. 树节点的第 K 个祖先(倍增 Java)

目录 1483. 树节点的第 K 个祖先 题目描述&#xff1a; 实现代码与解析&#xff1a; 倍增 原理思路&#xff1a; 1483. 树节点的第 K 个祖先 题目描述&#xff1a; 给你一棵树&#xff0c;树上有 n 个节点&#xff0c;按从 0 到 n-1 编号。树以父节点数组的形式给出&#…

软件测试——黑盒测试

黑盒测试也就是针对功能进行测试&#xff0c;白盒测试就是后端根据自己的代码逻辑进行一下自测&#xff0c;灰盒测试就是黑盒和白盒的混合测试。 1.黑盒测试主要发现以下类型的错误 对比需求规格说明书功能遗漏或者不一致。 接口错误 数据库连接访问错误 效率不高&#xff…

【好书推荐-第十四期】《 互联网大厂晋升指南:从P5到P9的升级攻略》

&#x1f60e; 作者介绍&#xff1a;我是程序员洲洲&#xff0c;一个热爱写作的非著名程序员。CSDN全栈优质领域创作者、华为云博客社区云享专家、阿里云博客社区专家博主、前后端开发、人工智能研究生。公众号&#xff1a;洲与AI。 &#x1f388; 本文专栏&#xff1a;本文收录…

第八讲 Sort Aggregate 算法

我们现在将讨论如何使用迄今为止讨论过的 DBMS 组件来执行查询。 1 查询计划【Query Plan】 我们首先来看当一个查询【Query】被解析【Parsed】后会发生什么&#xff1f; 当 SQL 查询被提供给数据库执行引擎&#xff0c;它将通过语法解析器进行检查&#xff0c;然后它会被转换…

机器人力觉控制(力源)原理及力矩传感器性能分析

机器人力控原理及其性能分析 在机器人的操作任务中&#xff0c;处理机器人和环境之间的物理接触是非常重要的。由于机器人系统的复杂性和不确定性&#xff0c;纯运动控制往往是不够的&#xff0c;因为即使是最精确的模型也无法完全准确地预测所有可能的情况。 当机器人在与环境…

arm开发板移植工具mkfs.ext4

文章目录 一、前言二、手动安装e2fsprogs1、下载源码包2、解压源码3、配置4、编译5、安装 三、移植四、验证五、总结 一、前言 在buildroot菜单中&#xff0c;可以通过勾选e2fsprogs工具来安装mkfs.ext4工具&#xff1a; Target packages -> Filesystem and flash utilit…

vue3中mars3d通过滑动条去改变地图图层的透明度

效果图 加滑动条 因为我这个存在单选框&#xff0c;在点击滑动条的时候 会出现将单选框选中的问题&#xff0c;所以用了一个div把滑动条包裹起来并加了冒泡 changeLiveSituationBg方法 // 改变底图显示颜色 val是我点击这个单选框对应值 const changeLiveSituationBg va…

5G智慧地铁数字孪生可视化平台,推进铁路行业数字化转型

随着科技的快速发展&#xff0c;5G智慧地铁数字孪生可视化平台正逐渐成为铁路行业数字化转型的重要推动力。巨蟹数科数字孪生平台集成了5G通信技术、大数据分析、云计算和人工智能等先进技术&#xff0c;通过构建数字孪生模型&#xff0c;实现对地铁运营全过程的实时监控、预测…

互联网大厂都在用的DevOps工具,看看你会几样?

关注公众号&#xff1a;“DevOps实战派”&#xff0c;获取更多DevOps和运维的精彩内容。 DevOps 是一种强调开发与 IT 运营之间合作的软件开发范式&#xff0c;主要依靠自动化来优化流程、提高生产力并确保及时、可靠的软件交付。 下面&#xff0c;我将介绍目前在互联网大厂中…

【7】双向循环链表

【7】双向循环链表 1、双向循环链表2、添加3、删除 1、双向循环链表 &#x1f58a; 头节点的 prev 指向尾节点 &#x1f58a; 尾节点的 next 指向头节点 2、添加 /*** 往索引位置添加元素*/Overridepublic void add(int index, E element) {checkIndex4Add(index);if (index s…