MySQL——UNION 与LIMIT
程序员文章站
2022-03-09 20:35:20
MySQL自我学习路线UNION概述LIMIT概述LIMIT分页所用数据库——链接地址UNION概述UNION 操作符用于合并两个或多个 SELECT 语句的结果集UNION 内部的 SELECT 语句必须拥有相同数量的列 ,列拥有相似的数据类型(不一定相同);UNION 后面字段的名称以第一条SQL为准UNION 是对数据进行并集操作,默认去重,同时进行默认排序UNION ALL效率快,UNION ALL是对数据进行并集操作,不去重,不进行排序如果想使用ORDER BY或LIMIT子句来...
所用数据库——链接地址
UNION
概述
- UNION 操作符用于合并两个或多个 SELECT 语句的结果集
- UNION 内部的 SELECT 语句必须拥有相同数量的列 ,列拥有相似的数据类型(不一定相同);UNION 后面字段的名称以第一条SQL为准
- UNION 是对数据进行并集操作,默认去重,同时进行默认排序
- UNION ALL效率快,UNION ALL是对数据进行并集操作,不去重,不进行排序
- 如果想使用ORDER BY或LIMIT子句来对全部UNION结果进行分类或限制,则应对单个地SELECT语句加圆括号,并把ORDER BY或LIMIT放到最后一个的后面
LIMIT
概述
- LIMIT是MySQL中特有的,其他数据库中没有,不通用(Oracle中有一个相同的机制叫做ROWNUM)
- LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数,LIMIT 接受1个或2个数字参数,参数必须是一个整数常量
- 语法:
LIMIT 偏移量,行数
偏移量从0开始,表示第1条记录
行数从偏移量+1开始,表示取行数条
LIMIT 3,4 /*取出第4条至第7条,4条记录*/
- 为了检索从某一个偏移量到记录集结束所有的记录行,可以指定第二个参数为 -1
LIMIT n,-1
- 如果只给定一个参数,它表示返回最大的记录行数目
LIMIT n
LIMIT n 等价于 LIMIT 0,n
LIMIT分页
- 每页显示pageSize条记录:
第pageNo页:(pageNo-1)*pageSize,pageSize
LIMIT(pageNo-1)*pageSize,pageSize - 越往后分页,LIMIT语句的偏移量就会越大,速度会明显变慢,此时可以通过子查询的方式来提高分页效率
SELECT a FROM A WHERE a.id = 1 ORDER BY id LIMIT 10000, 10
通过子查询优化:
SELECT a FROM A WHERE id >= (SELECT id FROM A WHERE a.id = 1 ORDER BY id LIMIT 10000, 1) LIMIT 10
本文地址:https://blog.csdn.net/LvJzzZ/article/details/109002019