一、DQL介绍

  DQL全称:Data Query Language(数据查询语言),用来查询数据库中表的记录。

  关键字:select

二、DQL语法

  select 字段列表 from 表名列表 where 条件列表 group by 分组字段列表 having 分组后条件列表 order by 排序字段列表 limit 分页参数

  注意:本章节只涉及到单表查询,多表查询会在后面的文章中介绍

三、基本查询

  1、原始表数据

    

  2、查询多个字段

    语法:select 字段1,字段2,... from 表名 或者 select * from 表名(查询所有数据)

    查询指定字段

    

  3、设置别名

    语法:select 字段1  [as 别名1], 字段2 [as 别名2] ... from 表名;

    对查询结果设置别名

    

  4、去重查询

    语法:select distinct 字段列表 from 表名;      

    

四、条件查询

  语法:select 字段列表 from 表名 where 条件列表  

 
运算符 功能
> 大于
>= 大于等于
< 小于
<= 小于等于
<> 或 != 不等于
between ... and ... 在某个范围之间(包含最大值和最小值)
in(...) 在in之后的列表中的值,多选一
like 占位符 模糊匹配( "_" 匹配单个字符,"%"匹配任何字符)
is null 是null
and 或者 && 并且
or 或者 || 或者
not 或者 !

  1、查询年龄等于18的所有人的姓名

    

  2、查询年龄小于21的人的姓名 

    

  3、查询年龄大于18,小于20的

    

  4、查询地址不为空的人的姓名和地址信息  

    

  5、查询年龄小于20并且地址在西安的人的姓名和地址

    

  6、查询地址在列表["北京","上海","广州","深圳"]中的人的姓名和地址

    

五、聚合函数

  1、介绍

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

  2、常见聚合函数

    count:统计数量

    max: 最大值

    min:最小值

    avg:平均值

    sum:求和

  3、语法

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

  4、示例

    4.1 统计table_test表中一共有多少数据

    

    4.2 统计table_test表中年龄最大的数据

    

    4.3 统计table_test表中年龄最小的数据

    

    4.4 统计table_test表中年龄的平均值

    

    4.5 统计table_test表中所有人的年龄之和

    

    4.6 统计北京地区所有员工的年龄之和 

    

    注意:在使用聚合函数的时候,所有的null值是不参与运算的,虽然table_test表中有6个数据,但是address列有一个是null,所以统计address字段时是5

    

六、分组查询

  1、语法:

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

  2、where与having区别

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

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

  3、示例

    3.1 统计不同地区的平均年龄,需要根据address做分组

    

    3.2 统计各个地区的平均年龄(不统计空地区的),先使用where做条件筛选,然后再分组

    

    3.3 统计各个地区的平均年龄(不统计空地区),并且显示平均年龄要大于19岁的

     

    注意:

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

      2、分组之后,查询的字段一般为聚合函数和分组字段,查询其他字段没有意义

七、排序查询

  1、语法:

    select 字段列表 from 表名 order by 字段1 排序方式1, 字段2 排序方式2;

  2、排序方式

    ASC:升序(默认)

    DESC:降序

  3、示例

    3.1 table_test表中数据按照年龄升序排列

      

    3.2 table_test 表中数据按照年龄降序排列

      

    3.3 table_test 表中数据按照年龄降序排列,年龄一样的,在继续按照id降序排列

      

八、分页查询

  1、语法

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

  2、注意

    * 其实索引从0开始,其实索引等于(查询页码-1)* 每页显示的记录数

    * 分页查询是数据库的方言,不同的数据库有不同的实现,mysql中是limit

    * 如果查询的是第一页,起始索引可以省略,直接写为limit 数量

  3、示例

    3.1 查询第一页数据,每页展示5条数据

      

    3.2 查询第二页数据,每页展示5条数据,因为每页的数据是5条,所以第二页的索引其实位置是(2-1)*5 = 5,第三页的起始位置是(3-1)*5=10

      又因为一共只有6条数据,所以第二页只有一条数据可以展示

      

九、DQL执行顺序

  

      

Mysql基础4-数据查询的更多相关文章

  1. MySQL基础架构之查询语句执行流程

    这篇笔记主要记录mysql的基础架构,一条查询语句是如何执行的. 比如,在我们从student表中查询一个id=2的信息 select * from student where id=2; 在解释这条 ...

  2. MySQL单表数据查询(DQL)

    数据准备工作: CREATE TABLE student( sid INT PRIMARY KEY AUTO_INCREMENT, sname ), age TINYINT, city ), scor ...

  3. MySQL多表数据查询(DQL)

    数据准备: /* ------------------------------------创建班级表------------------------------------ */ CREATE TAB ...

  4. Mysql对表中 数据 查询的操作 DQL

    准备数据,倒入sql文件 运行sql文件 得到四张表 select * from 表名  * 代表全部 1.AS子句作为别名 select studentname as "姓名" ...

  5. 关于mysql中的数据查询—嵌套查询

    嵌套查询 一个SELECT  FROM  WHERE语句称为一个查询块. 嵌套查询:将一个查询块嵌套在另一个查询块的WHERE子句或者HAVING短语的条件中的查询. 注:子查询的SELECT语句中不 ...

  6. MySQL基础7-分页查询

    1.分页查询(MySQL特有的,oracle中没有) 栗子1: 每页最多3条记录:pageSize=3:第一页:SELECT * FROM product LIMIT 0,3第二页:SELECT * ...

  7. MySQL基础语句(查询)

    students表 id class_id name gender score 1 1 小明 M 90 2 1 小红 F 95 3 1 小军 M 88 4 1 小米 F 73 5 2 小白 F 81 ...

  8. MySql基础学习-数据操作

    对于数据的操作,无非是“增删该查”这几种操作. 1增加 数据的增加使用insert语句插入 语法:INSERT INTO TABLE_NAME(column1,column2,...)VALUES(v ...

  9. MySQL基础6-分组查询

    1.分组函数 需求20:查询所有商品平均零售价SELECT AVG(salePrice) FROM product 需求21:查询商品总记录数SELECT COUNT(id) count FROM p ...

  10. MySQL基础4-SQL简单查询(单表)

    1.SELECT语句 2.运算符的优先级 利用Navicat中的查询方法: 栗子1:查询所有货品信息 栗子2:查询所有货品的id,productName,salePrice 当查询错误的时候出现的界面 ...

随机推荐

  1. 每天掌握10道面试题,轻轻松松去面试(Yes, that's right, I'm kidding)!!!

    一.4.12 1.说一说cookie sessionStorage localStorage 是什么,有什么区别? Cookie.sessionStorage 和 localStorage 都是在浏览 ...

  2. Python 组织列表

    组织列表 在创建的列表中,元素的排列顺序是无法预测的,不能总控制用户提供数据的顺序,通过组织列表的方式,来控制列表的排序 使用方法sort()对列表进行永久性排序 sort()方法:列表中值时小写时默 ...

  3. Bing的AI聊天使用体验

    Bing开启了AI聊天功能,我们这里做一个简单的测评,看看各种AI是否达到预期效果. PS:没有"魔法"的各位就不用看下去了 1.登陆 打开edge,遇到的第一个问题就是,使用&q ...

  4. [python] Python类型提示总结

    Python3.5 版本引入了类型提示(Type Hints),它允许开发者在代码中显式地声明变量.函数.方法等的类型信息.这种类型声明不会影响 Python 解释器的运行,但可以让 IDE 和静态分 ...

  5. 2022-11-22:小美将要期中考试,有n道题,对于第i道题, 小美有pi的几率做对,获得ai的分值,还有(1-pi)的概率做错,得0分。 小美总分是每道题获得的分数。 小美不甘于此,决定突击复习,

    2022-11-22:小美将要期中考试,有n道题,对于第i道题, 小美有pi的几率做对,获得ai的分值,还有(1-pi)的概率做错,得0分. 小美总分是每道题获得的分数. 小美不甘于此,决定突击复习, ...

  6. MySQL的varchar存储原理:InnoDB记录存储结构

    摘要:varchar(M) 能存多少个字符,为什么提示最大16383?innodb怎么知道varchar真正有多长?记录为NULL,innodb如何处理?某个列数据占用的字节数非常多怎么办?影响每行实 ...

  7. 解决 VMware EXSI的Windows虚拟机中,配置静态IP后,DHCP自动默认开启获取IP,导致无法访问

    解决 VMware EXSI的Windows虚拟机中,配置静态IP后,DHCP自动默认开启获取IP,导致无法访问 前言:在EXSI上部署了Windows虚拟机,但是配置了静态IP后却不能Ping通:逐 ...

  8. Django-管理员用户的创建

    命令:python manage.py createsuperuser python manage.py createsuperuser Type 'manage.py help' for usage ...

  9. vue-admin-template包下载地址

    https://gitee.com/panjiachen/vue-admin-template/ https://github.com/PanJiaChen/vue-admin-template

  10. nodejs 中 stream.pipe()直接将文件输出到页面乱码

    最近仿照anywhere写个anyentry目录读取器,发现使用stream.pipe()将文件输入到页面时,出现中文乱码 看哇 看到着实不爽,不解决咋能算 于是开始寻找问题根源 一.配置encodi ...