MySQl----完成DQL语句的学习----分页查询,DQL语句练习,DQL语句的编写顺序与执行顺序

首先,是分页查询:

分页查询是DQL查询语句的最后一个部分

这里会有一个关键字:LIMIT

分页查询的语法:

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

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

分页查询是数据库的方言(指的是数据库之间不同的地方),不同的数据库有不同的实现,MySql中就是limit。

如果查询是从第一页开始的,起始索引可以忽略,直接简写为limit 10.

通过需求来展现分页查询的用法:

一.查询第一页员工的数据,每页展示10条记录

select * from ts limit 0,10;

当然,也可以进行简写:select * from ts limit 10;

从第一页开始查询的

需求二:从第二页开始查询,每页展示10条记录。

select * from ts limit 10,10;

也可以这样理解,查询的就是从记录到记录,起始索引也有个公式,比如说,从第二页开始查询,那么起始索引就是(页码-1)*页展示的记录数。

DQL语句的练习:

以下五个需求练习:

1.查询年龄为20,21,22,23岁的员工信息.

select *from ts where age in (20,21,22,23);

2.查询性别为男,并且年龄在20-40岁以内的姓名为三个字的员工。

select from ts where gender='男'and age >=20 and age<=40 and name like'';
select *from ts where gender='男'and age( between 20 and 40 )and name like '
* ';
3.统计员工表中,年龄小于60岁的,男性员工和女性员工的人数。
select gender,count(* ) from ts where age<60 group by gender;

4.查询所有年龄小于等于35岁的员工的姓名和年龄,并对查询结果按年龄升序排序,如果年龄相同按照入职顺序降序排序。

select name,age from ts where age<35 order by age asc,entrydate desc ;

5.查询性别为男,且年龄在20-40岁以内的前五个员工信息,对查询的结果按年龄升序排序,年龄相同按入职时间升序排序。

select * from ts where age between 10 and 40 and gender='男' order by age asc ,entrydate asc limit 5;

DQL语句的编写顺序和执行顺序:

我们做了很多DQL语句的练习,知道了DQL语句很多都需要一层一层的往上加,所以很多时候就会有困扰,DQL语句在哪里加什么东西,这里给大家解释一下:

DQL语句是有编写顺序的,每一个关键字都是有划分依据的:

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

这是查询的时候所需要的东西,一定需要谨记。

那么执行顺序呢,就是先会执行哪一个关键字所对应的东西:

执行顺序就是:

from->where->group by->having->select->order by->limit.

相关推荐
Shannon Law几秒前
【免费下载】关于机器学习和深度学习的书籍
学习
Master_oid1 分钟前
机器学习28:增强式学习(Deep Reinforcement Learn)③
人工智能·学习·机器学习
fjkxyl3 分钟前
Redis 跳表技术博客:为什么不选用红黑树和 B+ 树
数据库·redis·缓存
我命由我123458 分钟前
开发中的英语积累 P25:Axis、Stroke、Corner、Interceptor、Declared、Internal
经验分享·笔记·学习·职场和发展·求职招聘·职场发展·学习方法
张人玉9 分钟前
整合 Sugar ORM 连接 SQLite 数据库到 WPF 折线图项目
数据库·sqlite·c#·wpf
、BeYourself10 分钟前
PGvector :在 Spring AI 中实现向量数据库存储与相似性搜索
数据库·人工智能·spring·springai
a1879272183116 分钟前
MySQL 硬件优化和操作系统优化
数据库·mysql·优化·raid·numa·sysbench·系统参数
CodeAmaz17 分钟前
mysql深度分页解决方案大全
mysql·深度分页
BIBI204918 分钟前
CentOS 7 安装 MySQL 5.7
linux·mysql·centos·配置·环境搭建·安装教程·服务器运维
只想早点退休的90后19 分钟前
sql面试题分享
数据库·sql