MySQL 篇-深入了解 DML、DQL 语言(二)

 🔥博客主页: 【小扳_-CSDN博客】
❤感谢大家点赞👍收藏⭐评论✍

 

文章目录

        1.0 DML、DQL 语言说明

        2.0 使用 DML 实现对数据管理和操作 

        2.1 DML - 增添数据 insert

        2.2 DML - 修改数据 update

        2.3  DML - 删除数据 delete

        3.0 使用 DQL 实现对数据管理和操作 

        3.1 DQL - 基本查询

        3.2 DQL - 条件查询

        3.3 DQL - 分组查询

        3.4 DQL - 排序查询

        3.5 DQL - 分页查询

        4.0 补充相关的函数


        1.0 DML、DQL 语言说明

        DML (Data Manipulation Language) 是用于管理数据库中数据的语言,用于对数据库中的数据进行增加、删除、修改。常见的 DML 操作包括 INSERT、UPDATE、DELETE 。

        DQL (Data Query Language) 是用于查询数据库中数据的语言,用于从数据库中检索所需的数据。常见的 DQL 操作是 SELECT,用于从数据库中检索数据并返回结果集。

        简单来说,DML、DQL 是对表中的数据进行操作,其中 DML 对表中的数据操作有:增添、删除、修改操作,而 DQL 对表中的数据操作有:查询操作。 两者结合使用可以实现对数据库的完整管理和操作。

        

        2.0 使用 DML 实现对数据管理和操作 

        常见的 DML 操作包括 INSERT、UPDATE、DELETE 。

        2.1 DML - 增添数据 insert

一、添加表中数据的 SQL 语句:

-- 指定字段添加数据:
insert into 表名 (字段名1,字段名2) values (值1,值2);-- 全部字段添加数据:
insert into 表名 values (值1,值2,...);-- 批量添加数据 (指定字段):
insert into 表名 (字段名1,字段名2) values (值1,值2),(值1,值2);-- 批量添加数据 (全部字段):
insert into 表名 values (值1,值2,...),(值1,值2,...);

二、实际需求操作:

1)

-- 指定字段增添数据
insert into tb_user (id,username,name) values (2,'张三','李四');

操作结果为:

2)

-- 全部字段增添数据
insert into tb_user values (3,'呆呆','王五',18,'女');

操作结果为:

3)

-- 批量增添指定字段数据
insert into tb_user (id,username,name) values (5,'白白','天天'),(6,'红红','火火');

操作结果为:

4)

-- 批量增添全部字段数据
insert into tb_user values (9,'恍恍','忽忽',20,'男'),(10,'吱吱','喳喳',30,'男');

操作结果为:

三、注意事项:

        1)插入数据时,指定的字段顺序需要与值的顺序是一一对应的。

        2)字符串和日期数据应该包含在引号中。

        3)插入的数据大小,应该在字段的规定范围内。

        2.2 DML - 修改数据 update

一、修改表中数据的 SQL 语句:

-- 修改数据:
update 表名 set 字段名1 = 值1,字段名2 = 值2,...[where 条件];

二、实际需求操作:

1)

-- 修改表中的指定的数据:
update tb_user set name = '恐龙' where id = 2;

该操作结果为:

2)

-- 修改表中的全部数据:
update tb_user set gender = '女';

该操作结果为:

三、注意事项:

        修改语句的条件可以有,也可以没有,如果没有条件,则会修改整张表的所有数据。

        2.3  DML - 删除数据 delete

一、删除表中数据的 SQL 语句:

-- 删除数据:
delete from 表名 [where 条件];

二、实际需要操作:

1)

-- 删除表中的指定数据:
delete from tb_user where id = 2;

该操作结果为:

2)

-- 删除表中全部数据;
delete from tb_user;

该操作结果为:

三、注意事项:

        - delete 语句的条件可以有,也可以没有,如果没有条件,则会删除整张表的所有数据。

        - delete 语句不能单独删除某一个字段的值(如果要操作,可以使用 update , 将该字段的值置为 null )。

        3.0 使用 DQL 实现对数据管理和操作 

        对表中的数据进行查询操作,主要的操作方式有:基本查询、条件查询、分组查询、排序查询、分页查询。

        3.1 DQL - 基本查询

一、对表中数据进行基本查询的 SQL 语句:

-- 查询多个字段:
select 字段名1,字段名2,字段名3 from 表名;-- 查询所有字段(通配符):
select * from 表名;-- 设置别名:
select 字段1 [as 别名1], 字段2 [as 别名2] from 表名;-- 去除重复记录:
select distinct 字段列表 from 表名;

二、实际需求操作:

1)

-- 基本查询:查询表中全部数据
select  id, username, name, age, gender from tb_user;
-- 也可以用 * 来替代 id, username, name, age, gender
select * from tb_user;

该操作结果为:

2)

-- 设置别名
select  name as 姓名,gender as 性别 from tb_user;

该操作结果为:

3)

-- 去除重复记录
select distinct gender from tb_user;

该操作结果为:

三、注意事项:

        * 号代表查询所有字段,在实际开发中尽量少用(不直观、影响效率)。

        3.2 DQL - 条件查询

一、对表中数据进行条件查询的 SQL 语句:

-- 条件查询:
select 字段列表 from 表名 where 条件列表;

 

比较运算符:

        >:大于

        >=:大于等于

        <:小于

        <=:小于等于

        =:等于

        <> 或者 !=:不等于

        between...and...:在某个范围之内(含最小、最大值)

        in(...):在 in 之后的列表中的值,多选一

        like 占位符:模糊匹配(_匹配单个字符,% 匹配任意个字符)

        is null:是 null

逻辑运算符:

        and 或 &&:并且(多个条件同时成立)

        or 或 || :或者(多个条件任意一个成立)

        not 或 ! :非,不是

二、实际需求操作:

-- 条件查询:查询表中指定的数据
select id, username, name, age, gender from tb_user where id = 2;
-- 同样可以用 * 来替代 id, username, name, age, gender
select * from tb_user where id = 2;-- 查询 age 为 null 的数据
select * from tb_user where age is null;-- 查询姓李的数据
select * from tb_user where name like '李%';-- 查询姓名为两个字的数据
select * from tb_user where name like '__';-- 查询id为:2,3的数据
select * from tb_user where id in (2,3);-- 查询姓名为李四且年龄为null的数据
select * from tb_user where age is null and name = '李四';

        具体操作结果就不过多赘述了。

        3.3 DQL - 分组查询

一、对表中数据进行分组查询的 SQL 语句:

-- 分组查询:
select 字段列表 from 表名 [where 条件] group by 分组字段名 [having 分组后过滤条件];

补充聚合函数说明:        

        聚合函数介绍:将一列数据作为一个整体,进行纵向计算。

        语法:select 聚合函数(字段列表) from 表名;

        主要的聚合函数:

                - count:统计数量

                - max:最大值

                - min:最小值

                - avg:平均数

                - sum:求和

二、实际需求操作:

1)

-- 根据性别分组,分别统计男、女人数总量
select gender '性别' , count(gender) '数量' from tb_user group by gender;

该操作结果为:

2)

-- 对分完组之后的表进行过滤 having
select gender '性别' , count(gender) '数量' from tb_user group by gender having count(gender) > 2;

该操作结果为:

三、注意事项:

        分组之后,查询的字段一般为聚合函数与分组字段,查询其他字段无任何意义。

        执行顺序:where > 聚合函数 > having 。

        where 与 having 区别:

        (1)执行时机不同:where 是分组之前进行过滤,不满足 where 条件,不参与分组;而 having 是分组之后对结果进行过滤。

        (2)判断条件不同:where 不能对聚合函数进行判断,而 having 可以。

        3.4 DQL - 排序查询

一、对表中数据进行排序的 SQL 语句:

-- 排序查询:
select 字段列表 from 表名 [where 条件列表] [group by 分组字段] order by 字段1 排序方式1,字段2 排序方式2...;

排序方式:

        升序为:asc(默认值)

        降序为:desc

二、实际需求操作:

1)

​
-- 按照 id 进行降序排序
select * from tb_user order by id desc;​

该操作结果为:

2)

-- 按照年龄进行降序排序,若年龄相同则按照id降序排序
select * from tb_user order by name desc, id desc;

该操作结果为:

三、注意事项:

        如果是多字段排序,当第一个字段值相同时,才会根据第二个字段进行排序。

        3.5 DQL - 分页查询

一、对表中数据进行分页查询的 SQL 语句:

-- 分页查询
select 字段列表 from 表名 limit 起始索引,查询记录数;

        默认起始索引为 0 ,即从 0 开始,公式:起始索引 = (页码 - 1)* 记录数 。

二、实际需求操作:

-- 查询第2页数据,则该起始索引为 3
select * from tb_user limit 3,3;

该操作结果为:

三、注意事项:

        (1) 起始索引从 0 开始,起始索引 = (查询页码 - 1) * 每页显示记录数。

        (2) 分页查询时数据库的方言,不同的数据库有不同都实现,MySQL 中是 limit 。

        (3) 如果查询的是第一页,起始索引可以省略,直接简写为 limit 10 。

        4.0 补充相关的函数

        

if (表达式,tvalue,fvalue):当表达式为 true 时,取值 tvalue;当表达式为 false 时,取值 fvaluecase 表达式 when value1 then result1 [when value2 then result2] [else result] end

 

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

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

相关文章

Data Leakage and Evaluation Issues inMicro-Expression Analysis 阅读笔记

IEEE Transactions on Affective Computing上的一篇文章&#xff0c;做微表情识别&#xff0c;阅读完做个笔记。本文讨论了Data Leakage对模型准确度评估的影响&#xff0c;及如何融合多个微表情数据集&#xff0c;从而提升模型的准确度。工作量非常饱满&#xff0c;很认真&…

信息学竞赛CSP中组合数学知识进阶及经典题目

组合数学 组合数卷积&#xff08;范德蒙德卷积&#xff09; ∑ i 0 k ( n i ) ( m k − i ) ( n m k ) \sum_{i0}\limits^k\dbinom{n}{i}\dbinom{m}{k-i}\dbinom{nm}{k} i0∑k​(in​)(k−im​)(knm​) 组合意义&#xff1a;有 n n n 个红球以及 m m m 蓝球&#xff0c;…

线上故障的排查清单

线上故障主要会包括CPU、磁盘、内存以及网络问题&#xff0c;而大多数故障可能会包含不止一个层面的问题&#xff0c;所以进行排查时候尽量四个方面依次排查一遍。 同时例如 jstack、jmap 等工具也是不囿于一个方面的问题的&#xff0c;基本上出问题就是df、free、top 三连&am…

全网最详细Python自动化测试(从零搭建完整python自动化测试框架)

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 关注公众号&#xff1a;互联网杂货铺&#xff0c;回复1 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 自动化测试介绍 自动化测试(Automated Testing)&#x…

基于java Springboot实现课程评分系统设计和实现

基于java Springboot实现课程评分系统设计和实现 博主介绍&#xff1a;多年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 央顺技术团队 Java毕设项目精品实战案例《1000套》 欢迎点赞 收藏 ⭐留言 文末获取源…

SpringMVC 学习(五)之域对象

目录 1 域对象介绍 2 向 request 域对象共享数据 2.1 通过 ServletAPI (HttpServletRequest) 向 request 域对象共享数据 2.2 通过 ModelAndView 向 request 域对象共享数据 2.3 通过 Model 向 request 域对象共享数据 2.4 通过 map 向 request 域对象共享数据 2.5 通过…

Ant for Blazor做单个表的增删查改

Ant for Blazor做单个表的增删查改 2024年02月27日花了一天时间弄出来了&#xff0c;基本弄好了&#xff0c;vs2022blazor servernet8,引用的AntDesign版本是0.17.4 代码里的model和repository是用自己牛腩代码生成器生成的东西&#xff0c;sqlsugar的&#xff0c;记得在prog…

分布式一致性算法-Paxos翻译和注解

Paxos是解决不可靠处理器&#xff08;不可靠是指处理器可能故障&#xff09;网络中一致性问题(consensus)的一个协议族。一致性&#xff08;或者共识&#xff09;是在一组参与者之间对一个结果达成共识的过程。当参与者或者它们的交互媒介可能发生故障的时候&#xff0c;这个问…

幻兽帕鲁(Palworld 1.4.11.5.0)私有服务器搭建(docker版)

文章目录 说明客户端安装服务器部署1Panel安装和配置docker服务初始化设置设置开机自启动设置镜像加速 游戏服务端部署游戏服务端参数可视化配置 Palworld连接服务器问题总结 服务端升级&#xff08;1.5.0&#xff09; 说明 服务器硬件要求&#xff1a;Linux系统/Window系统&a…

JS总览-JS高级程序设计4-学习笔记

JS简史 1995年 JS 问世&#xff0c;彼时其主要任务是替代服务器端语言处理输入验证 1995年网景公司的 Brendan Eich 开发了一个脚注Live Script的脚步语言&#xff0c;后来网景公司与 Sun 公司结盟&#xff0c;更名 Live Script 为 Java Script 由于微软发布 IE3 时包含了自己…

iMazing 3.0.0.3 for mac 中文破解版2024最新图文安装教程

我们刚刚发布了iMazing 3.0.0.3 for mac 中文版本。Windows和macOS用户现在都可以试驾并体验iPhone管理的未来。 备受期待的第一个Windows版本得益于过去几个月macOS测试版的所有改进&#xff0c;使其成为一个稳定的初始版本。 我们的开发团队创造了一种无缝的外观和体验&#…

关于uniapp小程序的分包问题

开发uniapp小程序时&#xff0c;在打包上传代码时会出现超出2M的打包限制不能上传&#xff0c;那么我们该怎么做呢&#xff1f; 1.对于图片&#xff0c;将图片从后端服务取&#xff0c;尽量不要放在静态资源&#xff0c;图片体积会影响打包大小。 2.使用分包&#xff0c;tabb…

LNMP 架构

PHP(Hypertext Preprocessor 超文本预处理器)是通用服务器端脚本编程语言&#xff0c;主要用于web开发实现动态web页面&#xff0c;也是最早实现将脚本嵌入HTML源码文档中的服务器端脚本语言之一。同时&#xff0c;php还提供了一个命令行接口&#xff0c;因此&#xff0c;其也可…

哪个牌子的电视盒子好用?2024超强电视盒子排名

最近很多朋友问我电视盒子的相关问题&#xff0c;就目前来说&#xff0c;电视盒子的地位依然是不可取代的。我近来要发布的测评内容是哪个牌子的电视盒子好用&#xff0c;耗时两周进行对比后整理了电视盒子排名&#xff0c;看看哪些电视盒子是最值得入手的吧。 NO.1——泰捷新品…

安装极狐GitLab Runner并测试使用

本文继【新版极狐安装配置详细版】之后继续 1. 添加官方极狐GitLab 仓库&#xff1a; 对于 RHEL/CentOS/Fedora&#xff1a; curl -L "https://packages.gitlab.com/install/repositories/runner/gitlab-runner/script.rpm.sh" | sudo bash2. 安装最新版本的极狐G…

ChatGPT提示词工程师AI大神吴恩达2023年视频课程学习实践

前言 刚才看了一个视频系列教程&#xff0c;很短&#xff0c;但收获很大&#xff0c;毕竟是一手知识来源&#xff0c;吴恩达大神亲自讲解&#xff0c;他说的话&#xff0c;我都信。这里写个笔记&#xff0c;顺便把知识点实践一下。视频可以去B站上搜索 吴恩达 prompt &#xf…

log4j 基础使用入门教程

一、Log4j介绍 在项目中&#xff0c;不管是开发人员写代码还是测试人员写的测试代码一般都需要做一些日志来记录项目的行为&#xff0c;以便更好的跟踪项目中的一些交互和问题。 Log4j ( Logger For Java ) , Java 日志的记录包。 官方网站 。Log4j 是 Apache 的一个开源项目…

C++之标准库中string的底层实现方式

目录 1、Eager Copy(深拷贝) 2、COW(Copy-On-Write)写时复制 2.1写时复制的实现 3、SSO&#xff08;Short String Optimization)短字符串优化 4、最佳策略 5、线程安全性 我们都知道&#xff0c; std::string的一些基本功能和用法了&#xff0c;但它底层到底是如何实现的…

李沐动手学习深度学习——3.4练习

理解极大似然估计 很巧妙的解释了为什么使用均方误差&#xff0c;因为均方误差是一种似然估计的变种&#xff0c;而对于逻辑回归softmax而言&#xff0c;更好的解释了其中存在exp 1. 我们可以更深入地探讨指数族与softmax之间的联系。 1. 计算softmax交叉熵损失l(y, ˆy)的二阶…

【C++历练之路】map与set的必备使用指南

W...Y的主页 &#x1f60a; 代码仓库的分享&#x1f495; &#x1f354;序言&#xff1a; C作为一门历史悠久且功能强大的编程语言&#xff0c;其标准模板库&#xff08;STL&#xff09;为开发者提供了一套丰富的数据结构和算法&#xff0c;极大地促进了软件开发的效率和质量…