MySQL之DQL(涵盖所有查询!!!)

news2024/11/18 15:39:49

文章目录

  • 前言
  • 一、基础查询
    • 1.1 语法
    • 1.2 实例
  • 二、条件查询
    • 2.1 语法
    • 2.2 条件查询实例
    • 2.3 模糊查询实例
  • 三 、排序查询
    • 3.1 语法
    • 3.2 实例
  • 四 、聚合函数
    • 4.1 概念
    • 4.2 聚合函数分类
    • 4.3 聚合函数语法
    • 4.4 实例
  • 五、分组查询
    • 5.1 语法
    • 5.2 实例
  • 六、分页查询
    • 6.1 语法
    • 6.2 实例

前言

   在上一篇博客中,我们详细介绍了MySQL的基础内容(MySQL简介与历史、安装与卸载、数据类型数据模型数据引擎以及账号管理和DDL操作数据库与表)。

   在篇博客中,我们来介绍MySQL的核心内容(其实也是所有数据库的核心内容)——查询操作,也就是DQL(Data Query Language数据查询语言) 。

在这里插入图片描述

   上图是我们在自定义MVC进阶中所做的一个简单的页面,展示书籍数据。而上图中的是最基本的查询效果,那么数据库其实是很多的,不可能在将所有的数据在一页进行全部展示,而页面上会有分页展示的效果,如下:

在这里插入图片描述

当然上图中的难度字段当我们点击也可以实现排序查询操作。从这个例子我们就可以看出,对于数据库的查询时灵活多变的,需要根据具体的需求来实现,而查询操作也是数据库最重要的操作。

接下来我们先介绍查询的完整语法:

SELECT 
    字段列表
FROM 
    表名列表 
WHERE 
    条件列表
GROUP BY
    分组字段
HAVING
    分组后条件
ORDER BY
    排序字段
LIMIT
    分页限定

为了给大家演示查询的语句,我们需要先准备表及一些数据:

-- 创建tb_stu表
CREATE TABLE tb_stu (
 id int, -- 编号
 name varchar(20), -- 姓名
 age int, -- 年龄
 sex varchar(5), -- 性别
 address varchar(100), -- 地址
 math double(5,2), -- 数学成绩
 english double(5,2), -- 英语成绩
 hire_date date -- 入学时间
);

-- 添加数据
INSERT INTO tb_stu(id,NAME,age,sex,address,math,english,hire_date) 
VALUES 
(1,'李白',55,'男','杭州',66,78,'2000-09-01'),
(2,'王昭君',45,'女','深圳',98,87,'2001-09-01'),
(3,'刘备',55,'男','香港',56,77,'1999-09-02'),
(4,'孙尚香',20,'女','湖南',76,65,'1997-09-05'),
(5,'孙策',20,'男','湖南',86,NULL,'2001-09-01'),
(6,'大乔',57,'男','香港',99,99,'2002-09-01'),
(7,'小乔',22,'女','香港',99,99,'2002-09-02'),
(8,'周瑜',18,'男','南京',56,65,'1999-09-03');

一、基础查询

1.1 语法

  • 查询多个字段
SELECT 字段列表 FROM 表名;
SELECT * FROM 表名; -- 查询所有数据
  • 去除重复记录
SELECT DISTINCT 字段列表 FROM 表名;
  • 起别名
AS: AS 也可以省略

1.2 实例

  • 查询name、age两列

    select name,age from tb_stu;
    

在这里插入图片描述

  • 查询所有列的数据,列名的列表可以使用*替代

    select * from tb_stu;
    

在这里插入图片描述

  • 查询地址信息

    select address from tb_stu;
    

    执行上面语句结果如下:

在这里插入图片描述

从上面的结果我们可以看到有重复的数据,我们也可以使用 distinct 关键字去重重复数据。

  • 去除重复记录

    select distinct address from tb_stu;
    

在这里插入图片描述

  • 查询姓名、数学成绩、英语成绩。并通过as给math和english起别名(as关键字可以省略

    select name,math as 数学成绩,english as 英文成绩 from tb_stu;
    select name,math 数学成绩,english 英文成绩 from tb_stu;
    

在这里插入图片描述

二、条件查询

2.1 语法

SELECT 字段列表 FROM 表名 WHERE 条件列表;
  • 条件

条件列表可以使用以下运算符

在这里插入图片描述

2.2 条件查询实例

  • 查询年龄大于等于20岁的学员信息

    select * from tb_stu where age >= 20;
    

    在这里插入图片描述

  • 查询年龄大于等于20岁 并且 年龄 小于等于 30岁 的学员信息

    select * from tb_stu where age >= 20 &&  age <= 30;
    select * from tb_stu where age >= 20 and  age <= 30;
    

    上面语句中 && 和 and 都表示并且的意思,建议使用 and

    也可以使用 between … and 来实现上面需求

    select * from tb_stu where age BETWEEN 20 and 30;
    

    在这里插入图片描述

  • 查询年龄不等于18岁的学员信息

    select * from tb_stu where age != 18;
    select * from tb_stu where age <> 18;
    

在这里插入图片描述

  • 查询年龄等于18岁 或者 年龄等于20岁 或者 年龄等于22岁的学员信息

    select * from tb_stu where age = 18 or age = 20 or age = 22;
    select * from tb_stu where age in (18,20 ,22);
    

    在这里插入图片描述

  • 查询英语成绩为 null的学员信息

    null值的比较不能使用 = 或者 != 。需要使用 is 或者 is not

    select * from stu where english = null; -- 这个语句是不行的
    select * from stu where english is null;
    select * from stu where english is not null;
    

2.3 模糊查询实例

模糊查询使用like关键字,可以使用通配符进行占位:

(1)_ : 代表单个任意字符

(2)% : 代表任意个数字符

  • 查询姓’马’的学员信息

    select * from tb_stu where name like '马%';
    
  • 查询第二个字是’花’的学员信息

    select * from tb_stu where name like '_花%';
    
  • 查询名字中包含 ‘德’ 的学员信息

    select * from tb_stu where name like '%德%';
    

三 、排序查询

3.1 语法

SELECT 字段列表 FROM 表名 ORDER BY 排序字段名1 [排序方式1],排序字段名2 [排序方式2];

上述语句中的排序方式有两种,分别是:

  • ASC : 升序排列 (默认值)
  • DESC : 降序排列

注意:如果有多个排序条件,当前边的条件值一样时,才会根据第二条件进行排序

3.2 实例

  • 查询学生信息,按照年龄升序排列

    select * from tb_stu order by age ;
    
  • 查询学生信息,按照数学成绩降序排列

    select * from tb_stu order by math desc ;
    
  • 查询学生信息,按照数学成绩降序排列,如果数学成绩一样,再按照英语成绩升序排列

    select * from tb_stu order by math desc , english asc ;
    

四 、聚合函数

4.1 概念

将一列数据作为一个整体,进行纵向计算。

如何理解呢?假设有如下表

在这里插入图片描述

现有一需求让我们求表中所有数据的数学成绩的总和。这就是对math字段进行纵向求和。

4.2 聚合函数分类

函数名功能
count(列名)统计数量(一般选用不为null的列)
max(列名)最大值
min(列名)最小值
sum(列名)求和
avg(列名)平均值

4.3 聚合函数语法

SELECT 聚合函数名(列名) FROM;

注意:null 值不参与所有聚合函数运算

4.4 实例

  • 统计班级一共有多少个学生

    select count(id) from tb_stu;
    select count(english) from tb_stu;
    

    上面语句根据某个字段进行统计,如果该字段某一行的值为null的话,将不会被统计。所以可以在count(*) 来实现。* 表示所有字段数据,一行中也不可能所有的数据都为null,所以建议使用 count(*)

    select count(*) from tb_stu;
    
  • 查询数学成绩的最高分

    select max(math) from tb_stu;
    
  • 查询数学成绩的最低分

    select min(math) from tb_stu;
    
  • 查询数学成绩的总分

    select sum(math) from tb_stu;
    
  • 查询数学成绩的平均分

    select avg(math) from tb_stu;
    
  • 查询英语成绩的最低分

    select min(english) from tb_stu;
    

五、分组查询

5.1 语法

SELECT 字段列表 FROM 表名 [WHERE 分组前条件限定] GROUP BY 分组字段名 [HAVING 分组后条件过滤];

注意:分组之后,查询的字段为聚合函数和分组字段,查询其他字段无任何意义

5.2 实例

  • 查询男同学和女同学各自的数学平均分

    select sex, avg(math) from tb_stu group by sex;
    

    注意:分组之后,查询的字段为聚合函数和分组字段,查询其他字段无任何意义

    select name, sex, avg(math) from tb_stu group by sex;  -- 这里查询name字段就没有任何意义
    
  • 查询男同学和女同学各自的数学平均分,以及各自人数

    select sex, avg(math),count(*) from tb_stu group by sex;
    
  • 查询男同学和女同学各自的数学平均分,以及各自人数,要求:分数低于70分的不参与分组

    select sex, avg(math),count(*) from tb_stu where math > 70 group by sex;
    
  • 查询男同学和女同学各自的数学平均分,以及各自人数,要求:分数低于70分的不参与分组,分组之后人数大于2个的

    select sex, avg(math),count(*) from tb_stu where math > 70 group by sex having count(*)  > 2;
    

where 和 having 区别:

  • 执行时机不一样:where 是分组之前进行限定,不满足where条件,则不参与分组,而having是分组之后对结果进行过滤。

  • 可判断的条件不一样:where 不能对聚合函数进行判断,having 可以。

六、分页查询

如下图所示,大家在很多网站都见过类似的效果,如京东、百度、淘宝等。分页查询是将数据一页一页的展示给用户看,用户也可以通过点击查看下一页的数据。

接下来我们先说分页查询的语法。

6.1 语法

SELECT 字段列表 FROM 表名 LIMIT  起始索引 , 查询条目数;

注意: 上述语句中的起始索引是从0开始

6.2 实例

  • 从0开始查询,查询3条数据

    select * from tb_stu limit 0 , 3;
    
  • 每页显示3条数据,查询第1页数据

    select * from tb_stu limit 0 , 3;
    
  • 每页显示3条数据,查询第2页数据

    select * from tb_stu limit 3 , 3;
    
  • 每页显示3条数据,查询第3页数据

    select * from tb_stu limit 6 , 3;
    

从上面的练习推导出起始索引计算公式:

起始索引 = (当前页码 - 1) * 每页显示的条数

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

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

相关文章

Docker 是什么,在 Ubuntu 虚拟机上安装(部署)Docker

本文目录 1. Docker 简介1.1 什么是 Docker1.2 Docker 与虚拟技术的区别和联系1.3 为什么要用 Docker 2. 几个基本概念2.1 镜像2.1.1 分层存储 2.2 容器2.3 仓库2.3.1 Docker Registry 公开服务2.3.2 私有 Docker Registry 3. Docker 安装3.1 卸载旧版本 Docker3.2 更新及安装工…

Visual Studio 2017下的C++开发环境搭建

Visual Studio 是Microsoft旗下的开发工具包系列产品&#xff0c;是一个基本完整的开发工具集&#xff0c;它包括整个软件生命周期中所需要的大部分工具&#xff0c;如UML工具、代码管控工具、集成开发环境(IDE)等等&#xff0c;是最流行的Windows平台应用程序的集成开发环境。…

动态规划之63 不同路径 II(第5道)

题目&#xff1a; 一个机器人位于一个 m x n 网格的左上角 &#xff08;起始点在下图中标记为 “Start” &#xff09;。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角&#xff08;在下图中标记为 “Finish”&#xff09;。 现在考虑网格中有障碍物。那…

ROS-Moveit和Gazebo联合仿真

文章目录 URDF功能包配置configlaunchCMakeLists.txtpackage.xmlurdf文件 Moveit功能包配置configlaunch 运行 URDF功能包配置 config 首先在SW2URDF生成的功能包下Config目录下新建文件joint_trajectory_controller.yaml robot_arm_controller:type: "position_contro…

Tomcat使用数据库连接池数据库

1.连接池技术的作用 数据池允许应用程序重复使用一个现有的数据库连接&#xff0c;而不是重新建立一个。这项技术能明显地提高对数据库操作的性能。 2.什么是连接池技术 数据库连接池在初始化时将创建一定数量的数据库连接&#xff0c;具体数量的由连接池的最小数据库连接数来设…

什么是Uniswap v3?

目录 1. 集中化流动性&#xff1a;2. 集中化资金池管理&#xff1a;3. 多个流动性池&#xff1a;4. 高级订单类型&#xff1a;5. 协议费用优化&#xff1a; Uniswap v3 是去中心化交易所 Uniswap 的第三个主要版本&#xff0c;它于2021年5月发布。相比于 Uniswap v2&#xff0c…

内嵌tomcat使用方式(读取web.xml)

pom <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0 http…

微信小程序之单选题按钮切换背景

先来效果图 未选效果 已选效果 上代码 <view class"questionClass">问题1&#xff1a;夜晚落地西安咯&#xff0c;你最想先去哪里看看呢&#xff1f;</view><view class"single"><ul class"box"><li v-for"(s,i…

Python获取豆丁文档数据内容, 保存word文档

前言 嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 开发环境: python 3.8 pycharm 模块使用: requests --> pip install requests re base64 docx --> pip install python-docx 第三方模块安装方法&#xff1a; win R 输入cmd 输入安装命令 pip install …

第N4周:使用Word2vec实现文本分类

目录 二、数据预处理1.加载数据2.构建词典3.生成数据批次和迭代器 二、模型构建1.搭建模型2.初始化模型3.定义训练与评估函数 三、训练模型1.拆分数据集并运行模型2.测试指定数据 &#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&…

原子操作CAS

CAS 悲观锁 具有强烈的独占和排他特性。在有悲观锁的情况下&#xff0c;对数据进行处理&#xff0c;数据会处于锁定状态。前面讲到的synchronized同一时间只允许一个线程访问某块资源&#xff0c;其他线程处于阻塞状态&#xff0c;就是一个独占锁&#xff0c;是悲观锁中的一种…

语义分割大模型SAM论文阅读(二)

论文链接 Segment Anything 开源代码链接 SAM 论文阅读 摘要 We introduce the Segment Anything (SA) project: a new task, model, and dataset for image segmentation. Using our efficient model in a data collection loop, we built the largest segmentation dat…

Presto启动报错:No such file or directory

1. 问题描述 1.1 无法通过sudo -u presto启动 使用低版本的Presto时&#xff0c;在root用户下&#xff0c;通过如下命令切换到presto用户、启动Presto服务&#xff1a; sudo -u presto /install_dir/bin/launcher start # 或直接restart&#xff0c;包含stop和start操作 sudo …

12.3 ARM寄存器组织

目录 ARM寄存器组织&#xff08;一&#xff09; 寄存器 概念 作用 分类 ARM寄存器 ARM寄存器组织&#xff08;二&#xff09; 专用寄存器 R15(PC,Program Counter) R14(LR,Link Register) R13(SP,Stack Pointer) ARM寄存器组织&#xff08;三&#xff09; CPSR寄存…

【Vue面试题系列】二

Vue3中的Treeshaking特性是什么&#xff1f;并举例说明。 是什么&#xff1f; treeshaking是一种通过清除多余代码方式来优化项目打包体积的技术。 简单来讲&#xff0c;就是在保持代码运行结果不变的前提下&#xff0c;去掉无用的代码。 如果把代码打包比作制作蛋糕&#xff…

将xxl-job集成到自己的项目中,部署并测试

文章目录 1、添加依赖2、application.yml 配置3、 新建配置类4、创建任务5、将项目打包&#xff0c;在服务器上运行6、编辑执行器机器地址7、测试 1、添加依赖 <dependency><groupId>com.xuxueli</groupId><artifactId>xxl-job-core</artifactId>…

常见排序算法—面试编程题2023

常见排序算法—面试编程题2023 最近在看一些面试题&#xff0c;发现很多面试过程中都会要求手写排序编程题&#xff0c;经过一番查找整理&#xff0c;可以快速学习和使用相关排序算法题&#xff0c;通俗易懂&#xff0c;手撕代码吊打面试官。 一、冒泡排序 冒泡排序 是一种简…

ETHERNET/IP 转ETHERCAT连接倍福和欧姆龙PLC的配置方法

ETHERNET/IP和ETHERCAT是两种不同的协议&#xff0c;它们在工业生产中都有广泛的应用。然而&#xff0c;由于协议不同&#xff0c;这两种设备之间无法通讯&#xff0c;这给工业生产带来了很大的麻烦。而远创智控YC-EIP-ECT网关应运而生&#xff0c;它能够连接到ETHERNET/IP总线…

路径规划算法:基于世界杯优化的路径规划算法- 附代码

路径规划算法&#xff1a;基于世界杯优化的路径规划算法- 附代码 文章目录 路径规划算法&#xff1a;基于世界杯优化的路径规划算法- 附代码1.算法原理1.1 环境设定1.2 约束条件1.3 适应度函数 2.算法结果3.MATLAB代码4.参考文献 摘要&#xff1a;本文主要介绍利用智能优化算法…

合合信息AI图像内容安全新技术亮相WAIC2023,防范“生成式造假”

开年以来&#xff0c;多个图像生成软件在全球迅速蹿红&#xff0c;其作画逼真程度“技惊四座”。AI一路“狂飙”&#xff0c;让生成、篡改等多形式的图片伪造的门槛变得更低&#xff0c;由此引发的隐患也令人忧虑。 图像是信息的主要载体之一&#xff0c;利用AI进行图像造假的…