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

相关文章:
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 实现对…...
端智能:面向手机计算环境的端云协同AI技术创新
近年来,随着移动端设备软硬件能力的进步,移动端的算力有了很大提升,同时面向移动端的机器学习框架和模型轻量化技术越来越成熟,端上的AI能力逐渐进入大众视野,端智能在电商领域也开始逐步走向规模化应用。通过持续探索…...
PHP函数 “password_hash“ 哈希密码
哈希函数是一种将输入转换为固定长度字符串的方法,这个过程是不可逆的,也就是无法从哈希值还原出原始输入。通过将密码进行哈希处理,即使数据库泄露,攻击者也无法简单地获取到用户密码。 在PHP中,我们可以使用 "…...
第十一天-Excel的操作
目录 1.xlrd-Excel的读模块 安装 使用 获取工作簿 读取工作簿的内容 xlsxwriter-Excel的写模块 安装 使用 生成图表 add_series参数 图表的样式 demo:生成图表 Excel的操作在python中有多个模块,为了能够快速使用,选择了相对简单…...
【java任意文件漏洞修复,使用文件魔数解决】
java任意文件漏洞修复,使用文件魔数解决 背景: 客户进行渗透测试,验证上传文件的程序没有对上传文件作任何过滤,导致可以上传任意文件到服务器,甚至是病毒文件和Webshell木马文件。 解决办法:对于上传的附件…...
LeetCode 热题 100 | 二叉树(二)
目录 1 543. 二叉树的直径 2 102. 二叉树的层序遍历 3 108. 将有序数组转换为二叉搜索树 菜鸟做题,语言是 C 1 543. 二叉树的直径 这道题和 124. 二叉树中的最大路径和 太像了 题眼:二叉树的 直径 是指树中任意两个节点之间 最长路径的长度 。…...
mini-spring|定义标记类型Aware接口,实现感知容器对象
**前言:**如果我们想获得 Spring 框架提供的 BeanFactory、ApplicationContext、BeanClassLoader等这些能力做一些扩展框架的使用时该怎么操作呢。所以我们本章节希望在 Spring 框架中提供一种能感知容器操作的接口,如果谁实现了这样的一个接口ÿ…...
83. 删除排序链表中的重复元素
给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。 输入:head = [1,1,2] 输出:[1,2] 输入:head = [1,1,2,3,3] 输出:[1,2,3] 提示: 链表中节点数目在范围 [0, 300] 内-100 <= Node.val <= 100题目数据保证链表已…...
贪心算法
贪心算法 例题1、股票买卖题目信息思路题解 2、货仓选址题目信息思路题解 3、糖果传递题目信息思路题解 4、雷达设备题目信息思路题解 例题 1、股票买卖 题目信息 思路 相邻两天,后>前,则交易一次 题解 #include <bits/stdc.h> #define en…...
MySQL基本知识
目录 一,MySQL的元数据库 1.1.什么是元数据库 1.2.有哪些元数据库 1.3.切换数据库 二,账户管理 2.1.设置权限 2.2.授权用户 2.3.查看权限 2.4.撤销权限 三,MySQL引擎 3.1什么是数据库引擎 3.2.查看数据引擎 3.3.MyISAM引擎 3.4…...
Vue3 (unplugin-auto-import自动导入的使用)
安装 参考链接 npm i -D unplugin-auto-importvite.config.ts里面配置 import AutoImport from unplugin-auto-import/viteAutoImport({imports:[ vue,vue-router]})重新运行项目会生成一个auto-imports.d.ts的文件 /* eslint-disable */ /* prettier-ignore */ // ts-nochec…...
【漏洞复现】大华智慧园区综合管理平台信息泄露漏洞
Nx01 产品简介 大华智慧园区综合管理平台是一款综合管理平台,具备园区运营、资源调配和智能服务等功能。该平台旨在协助优化园区资源分配,满足多元化的管理需求,同时通过提供智能服务,增强使用体验。 Nx02 漏洞描述 大华智慧园区…...
JavaScript的书写方式
JavaScript的书写方式 目前较为流行的是第二种和第三种,第一种很少见。在第二种和第三种推荐使用第三种,因为在日常开发/工作中,第三种是最为常见的 1.行内式 把JS代码嵌入到html元素内部 示例代码 运行效果 由于JS中字符串常量可以使用单引…...
第二十篇-推荐-纯CPU(E5-2680)推理-llama.cpp-qwen1_5-72b-chat-q4_k_m.gguf
环境 系统:CentOS-7 CPU: Intel Xeon CPU E5-2680 v4 2.40GHz 14C28T 内存: 48G DDR3 依赖安装 make --version GNU Make 4.3gcc --version gcc (GCC) 11.2.1 20220127 (Red Hat 11.2.1-9)g --version g (GCC) 11.2.1 20220127 (Red Hat …...
CSS常见选择器
CSS常见选择器 在Web开发中,层叠样式表(CSS)是用于描述HTML或XML(包括SVG和XHTML等其他XML语言)文档的样式的语言。CSS描述了文档的表现形式,包括布局、颜色和字体等。在CSS中,选择器是一种模式…...
[LWC] Components Communication
目录 Overview Summary Sample Code 1. Parent -> Child - Public Setter / Property / Function a. Public Property b. Public getters and setters c. Public Methods 2. Child -> Parent - Custom Event 3. Unrelated Components - LMS (Lightning Message…...
Unity中URP实现水体(水下的扭曲)
文章目录 前言一、使用一张法线纹理,作为水下扭曲的纹理1、在属性面板定义一个纹理,用于传入法线贴图2、在Pass中,定义对应的纹理和采样器3、在常量缓冲区,申明修改 Tilling 和 Offset 的ST4、在顶点着色器,计算得到 应…...
anaconda指定目录创建环境无效/环境无法创建到指定位置
已经设置目录到D盘 创建环境时还是分配到C盘 可能是指定位置没有开启读写权限,如我在这里安装到了anaconda文件夹,则打开该文件夹的属性->安全->编辑 allusers下的权限全都打勾...
《Docker极简教程》--Docker在生产环境的应用--Docker在生产环境的部署
一、准备工作 1.1 硬件和基础设施要求 硬件和基础设施要求是在部署 Docker 到生产环境之前需要认真考虑和准备的重要方面,以下是一般性的要求: 服务器硬件: CPU:建议使用多核处理器,以支持同时运行多个容器。内存&a…...
算法D31 | 贪心算法1 | 455.分发饼干 376. 摆动序列 53. 最大子序和
贪心算法其实就是没有什么规律可言,所以大家了解贪心算法 就了解它没有规律的本质就够了。 不用花心思去研究其规律, 没有思路就立刻看题解。 基本贪心的题目 有两个极端,要不就是特简单,要不就是死活想不出来。 学完贪心之后再…...
Ruby 安装 - Linux
Ruby 安装 - Linux 引言 Ruby 是一种动态、开源的编程语言,广泛用于Web开发、脚本编写以及系统管理等领域。在 Linux 系统上安装 Ruby 是使用 Ruby 进行开发的第一步。本文将详细介绍如何在 Linux 系统上安装 Ruby,包括环境准备、安装方式以及常见问题解决。 环境准备 在…...
别再只用散点图了!用matplotlib的plt.contourf()给你的机器学习模型画个‘势力范围’
用等高线图解锁机器学习模型的决策奥秘 在机器学习的世界里,模型往往被视为一个"黑箱"——输入数据,输出结果,中间发生了什么却难以直观理解。这种不透明性让很多从业者感到困扰,尤其是在向非技术背景的利益相关者解释模…...
计算机毕业设计 | vue+SpringBoot凌云在线阅读平台 图书借阅管理系统(附源码)
1, 概述 1.1 课题背景 随着现在科学技术的进步,人类社会正逐渐走向信息化,图书馆拥有丰富的文献信息资源,是社会系统的重要组成部分,在信息社会中作用越来越重要,在我国图书馆计算机等 信息技术的应用起步…...
CSS 中实现同类型兄弟元素悬停联动效果(如所有红色行同时高亮)
本文介绍如何利用 css :has() 伪类实现“悬停任一同类元素时,所有同类型兄弟元素同步响应样式变化”,无需 javascript,纯 css 可控,适用于分组高亮等交互场景。 本文介绍如何利用 css :has() 伪类实现“悬停任一同类元素时&a…...
如何通过宝塔面板批量导出网站数据_使用宝塔命令行导出
宝塔命令行导出网站数据的正确入口是使用官方bt命令工具,通过bt 10(网站备份)或bt 11(数据库备份)子命令执行;需SSH登录root权限服务器,备份文件默认存于/www/backup/site/和/database/目录&…...
别只发GET请求了!ESP32的HTTPClient库POST数据到服务器,保姆级配置流程(含模拟测试)
ESP32实战:HTTPClient库POST数据全流程指南与模拟测试方案 在物联网开发中,数据采集只是第一步,如何将传感器数据可靠地上传到服务器才是真正体现项目价值的环节。很多开发者习惯使用GET请求获取数据,却忽视了POST请求在数据上传中…...
3分钟学会:如何将B站缓存视频完美合并为MP4并保留弹幕?
3分钟学会:如何将B站缓存视频完美合并为MP4并保留弹幕? 【免费下载链接】BilibiliCacheVideoMerge 🔥🔥Android上将bilibili缓存视频合并导出为mp4,支持安卓5.0 ~ 13,视频挂载弹幕播放(Android consolidate…...
C/C++构建共享库时链接静态库报错:dangerous relocation: unsupported relocation 的根源与解决
1. 为什么会出现"dangerous relocation"错误? 当你尝试将一个静态库链接到共享库(动态库)时,如果遇到"dangerous relocation: unsupported relocation"这样的错误信息,这通常意味着你的静态库没有…...
3步掌握FanControl:实现Windows风扇精准控制的完整指南
3步掌握FanControl:实现Windows风扇精准控制的完整指南 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/f…...
PTA天梯赛L2通关秘籍:从链表去重到彩虹瓶,这10道模拟题帮你避开所有坑
PTA天梯赛L2模拟题深度解析:从解题框架到实战技巧 在算法竞赛的世界里,PTA天梯赛作为国内最具影响力的程序设计赛事之一,其L2级别的题目往往成为选手晋级的关键门槛。而其中占比高达70%的模拟类题型,更是检验选手编程基本功和逻辑…...















