欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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子句来...

MySQL自我学习路线


所用数据库——链接地址

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