百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

MySQL基础篇:DQL数据查询操作_mysql 查

wptr33 2025-09-13 10:32 2 浏览

一、基础查询

  • DQL基础查询语法
  • SELECT 字段列表 FROM 表名列表 WHERE 条件列表 GROUP BY 分组字段列表 HAVING 分组后条件列表 ORDER BY 排序字段列表 LIMIT 分页参数
  • 为了查看效果,先创建一张表,并向表中插入数据
  • create table emp( id int comment '编号', workno varchar(10) comment '工号', name varchar(10) comment '姓名', gender char(1) comment '性别', age tinyint unsigned comment '年龄', idcard char(18) comment '身份证号', workaddress varchar(50) comment '工作地址', entrydate date comment '入职时间' ) comment '员工表'; insert into emp (id, workno, name, gender, age, idcard,workaddress, entrydate) values (1,'1','柳岩','女',20,'123456789012345678','北京','2000-01-01'), (2,'2','张无忌','男',18,'123456789012345670','北京','2005-09-01'), (3,'3','韦一笑','男',38,'123456789712345670','上海','2005-08-01'), (4,'4','赵敏','女',18,'123456757123845670','北京','2009-12-01'), (5,'5','小昭','女',16,'123456769012345678','上海','2007-07-01'), (6,'6','杨道','男',28,'12345678931234567X','北京','2006-01-01'), (7,'7','范瑶','男',40,'123456789212345670','北京', '2005-05-01'), (8,'8','黛绮丝','女',38,'123456157123645670','天津','2015-05-01'), (9,'9','范凉凉','女',45,'123156789012345678','北京','2010-04-01'), (10,'10','陈友谅','男',53,'123456789012345670','上海','2011-01-01'), (11,'11','张士诚','男',55,'123567897123465670','江苏','2015-05-01'), (12,'12','常遇春','男',32,'123446757152345670','北京','2004-02-01'), (13,'13','张三丰','男',88,'123656789012345678','江苏','2020-11-01'), (14,'14','灭绝','女',65,'123456719012345670','西安','2019-05-01'), (15,'15','胡青牛','男',70,'12345674971234567X','西安','2018-04-01'), (16,'16','周芷若','女',18,null,'北京','2012-06-01');
  • 查询多个字段
  • SELECT 字段1,字段2,... FROM 表名 SELECT * FROM 表名
  • 设置别名
  • SELECT 字段1 [AS 别名1],字段2 [AS 别名2],... FROM 表名
  • 去除重复记录
  • SELECT DISTINCT 字段列表 FROM 表名
  • 条件查询
  • SELECT 字段列表 FROM 表名 WHERE 条件列表
  • 条件
  • 比较运算符功能大于>=大于等于<小于<=小于等于=等于<>或 !=不等于BETWEEN ... AND ...在某个范围之内(含最小、最大值)IN(...)在in之后的列表中的值,多选一LIKE 占位符模糊匹配(_匹配单个字符,%匹配任意个字符)IS NULL是NULL逻辑运算符功能AND 或 &&并且OR 或 ||或者NOT 或 !非,不是

三、聚合函数

  • 聚合函数:将一列数据作为一个整体,进行纵向计算
  • 函数功能count统计数量max最大值min最小值avg平均值sum求和SELECT 聚合函数(字段列表) FROM 表名;

四、分组查询

  • 语法
  • SELECT 字段列表 FROM 表名 [WHERE 条件] GROUP BY 分组字段名 [HAVING 分组后过滤条件];
  • where和having区别
    • 执行实际不同:where是分组之前进行过滤,不满足where条件,不参与分组;而having是分组之后对结果进行过滤
    • 判断条件不同:where不能对聚合函数进行判断,而having可以
  • 注意
    • 执行顺序:where>聚合函数>having
    • 分组之后,查询的字段一般为聚合函数和分组字段,查询其他字段无任何意义

五、排序查询

  • 语法
  • SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式1, 字段2 排序方式2;
  • 排序方式
    • asc:升序(默认值)
    • DESC:降序
  • 注意:如果是多字段排序,当第一个字段值相同时,才会根据第二个字段进行排序

六、分页查询

  • 语法
  • SELECT 字段列表 FROM 表名 LIMIT 起始索引, 查询记录数;
  • 注意
    • 起始索引从0开始,起始索引=(查询页码-1)*每页显示记录数
    • 分页查询是数据库的方言,不同的数据库有不同的实现,MySQL是LIMIT
    • 如果查询的是第一页数据,起始索引可以省略,直接简写为limit 10

七、执行顺序

与编写顺序不同,执行顺序如下:

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

八、案例练习

现在来做一个小练习,按照需求完成如下DQL语句编写

  • 查询年龄为20,21,22,23岁的员工信息
  • SELECT * FROM emp where age = 20 || age = 21 || age = 22 || age = 23;
  • 查询性别为男,并且年龄在20-40岁(含)以内的姓名为三个字的员工
  • SELECT * FROM emp WHERE gender = '男' AND 20 <= age <= 40 AND name LIKE '___';
  • 统计员工表中,年龄小于60岁的,男性员工和女性员工的人数
  • SELECT gender, count(*) FROM emp WHERE age < 60 GROUP BY gender;
  • 查询所有年龄小于等于35岁员工的姓名和年龄,并对查询结果按年龄升序排序,如果年龄相同按入职时间降序排序
  • SELECT name, age FROM emp WHERE age <= 35 ORDER BY age, entrydate DESC;
  • 查询性别为男,且年龄在20-40岁(含)以内的前5个员工信息,对查询的结果按年龄升序排序,年龄相同按入职时间升序排序
  • SELECT * FROM emp WHERE gender = '男' AND 20 <= age <= 40 ORDER BY age, entrydate LIMIT 0, 5;

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...