首页 数据库 mysql教程 Mysql 分页语句Limit用法

Mysql 分页语句Limit用法

Jun 07, 2016 pm 03:34 PM
limit mysql 分页 用法 语句

1、Mysql的limit用法 在我们使用查询语句的时候,经常要返回前几条或者中间某几行数据,这个时候怎么办呢?不用担心, mysql 已经为我们提供了这样一个功能。 Sql代码 SELECT * FROM table LIMIT[offset,] rows | rows OFFSEToffset LIMIT 子句可以被用于强

1、Mysql的limit用法

 

在我们使用查询语句的时候,经常要返回前几条或者中间某几行数据,这个时候怎么办呢?不用担心,mysql已经为我们提供了这样一个功能。

 

Sql代码  Mysql 分页语句Limit用法

  1. SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset  

 

LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。初始记录行的偏移量是 0(而不是 1): 为了与 PostgreSQL 兼容,MySQL 也支持句法: LIMIT # OFFSET #。

 

Sql代码  Mysql 分页语句Limit用法

  1. mysql> SELECT * FROM table LIMIT 5,10; // 检索记录行 6-15  
  2.   
  3. //为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1:   
  4. mysql> SELECT * FROM table LIMIT 95,-1; // 检索记录行 96-last.  
  5.   
  6. //如果只给定一个参数,它表示返回最大的记录行数目:   
  7. mysql> SELECT * FROM table LIMIT 5; //检索前 5 个记录行  
  8.   
  9. //换句话说,LIMIT n 等价于 LIMIT 0,n。  

 

    【引用,路人乙:Mysql中limit的用法详解】

 

2、Mysql的分页查询语句的性能分析

 

 

      MySql分页sql语句,如果和MSSQL的TOP语法相比,那么MySQL的LIMIT语法要显得优雅了许多。使用它来分页是再自然不过的事情了。

 

2.1最基本的分页方式:

 

Sql代码  Mysql 分页语句Limit用法

  1.    
  2. SELECT ... FROM ... WHERE ... ORDER BY ... LIMIT ...  
  

在中小数据量的情况下,这样的SQL足够用了,唯一需要注意的问题就是确保使用了索引:

举例来说,如果实际SQL类似下面语句,那么在category_id, id两列上建立复合索引比较好:

 

Sql代码  Mysql 分页语句Limit用法

  1. SELECT * FROM articles WHERE category_id = 123 ORDER BY id LIMIT 50, 10  
  

 

2.2子查询的分页方式:

 

随着数据量的增加,页数会越来越多,查看后几页的SQL就可能类似:

Sql代码  Mysql 分页语句Limit用法

  1. SELECT * FROM articles WHERE category_id = 123 ORDER BY id LIMIT 10000, 10  
  

一言以蔽之,就是越往后分页,LIMIT语句的偏移量就会越大,速度也会明显变慢。

此时,我们可以通过子查询的方式来提高分页效率,大致如下:

Sql代码  Mysql 分页语句Limit用法

  1. SELECT * FROM articles WHERE  id >=  
  2.  (SELECT id FROM articles  WHERE category_id = 123 ORDER BY id LIMIT 10000, 1) LIMIT 10  
 

 

2.3JOIN分页方式

 

Sql代码  Mysql 分页语句Limit用法

  1. SELECT * FROM `content` AS t1   
  2. JOIN (SELECT id FROM `content` ORDER BY id desc LIMIT ".($page-1)*$pagesize.", 1) AS t2   
  3. WHERE t1.id ORDER BY t1.id desc LIMIT $pagesize;   
  

    经过我的测试,join分页和子查询分页的效率基本在一个等级上,消耗的时间也基本一致。

explain SQL语句:

id select_type table type possible_keys key key_len ref rows Extra

1 PRIMARY system NULL NULL NULL NULL 1  

1 PRIMARY t1 range PRIMARY PRIMARY 4 NULL 6264 Using where

2 DERIVED content index NULL PRIMARY 4 NULL 27085 Using index

 

----------------------------------------

 

为什么会这样呢?因为子查询是在索引上完成的,而普通的查询时在数据文件上完成的,通常来说,索引文件要比数据文件小得多,所以操作起来也会更有效率。

 

实际可以利用类似策略模式的方式去处理分页,比如判断如果是一百页以内,就使用最基本的分页方式,大于一百页,则使用子查询的分页方式。

【引用原文,energy1010的空间:MySql分页sql语句】

 

 

3、Oracle分页查询语句

Oralce数据库 

从数据库表中第M条记录开始检索N条记录 

Sql代码  Mysql 分页语句Limit用法

  1. SELECT * FROM (SELECT ROWNUM r,t1.* From 表名称 t1 where rownum 
  2.  where t2.r >= M   

  例如从表Sys_option(主键为sys_id)中从第10条记录开始检索20条记录,语句如下: 

Sql代码  Mysql 分页语句Limit用法

  1. SELECT * FROM (SELECT ROWNUM R,t1.* From Sys_option where rownum 
  2. Where t2.R >= 10   
  

3、MSSQLSERVER分页查询语句

 

SQL Server主要利用 SELECT TOP语句分页,具体方案,请参考

 

------------------------------------- 

 

分页方案一:(利用Not In和SELECT TOP分页) 

语句形式: 

 

Sql代码  Mysql 分页语句Limit用法

  1. SELECT TOP 10 *   
  2. FROM TestTable   
  3. WHERE (ID NOT IN   
  4. (SELECT TOP 20 id   
  5. FROM TestTable   
  6. ORDER BY id))   
  7. ORDER BY ID   
   

Sql代码  Mysql 分页语句Limit用法

  1. SELECT TOP 页大小 *   
  2. FROM TestTable   
  3. WHERE (ID NOT IN   
  4. (SELECT TOP 页大小*页数 id   
  5. FROM 表   
  6. ORDER BY id))   
  7. ORDER BY ID   
  8. SELECT TOP 页大小 *   

Sql代码  Mysql 分页语句Limit用法

  1. FROM TestTable   
  2. WHERE (ID >   
  3. (SELECT MAX(id)   
  4. FROM (SELECT TOP 页大小*页数 id   
  5. FROM 表   
  6. ORDER BY id) AS T))   
  7. ORDER BY ID   
  

------------------------------------- 

 

分页方案二:(利用ID大于多少和SELECT TOP分页) 

语句形式: 

Sql代码  Mysql 分页语句Limit用法

  1. SELECT TOP 10 *   
  2. FROM TestTable   
  3. WHERE (ID >   
  4. (SELECT MAX(id)   
  5. FROM (SELECT TOP 20 id   
  6. FROM TestTable   
  7. ORDER BY id) AS T))   
  8. ORDER BY ID   
  

------------------------------------- 

分页方案三:(利用SQL的游标存储过程分页) 

 

Sql代码  Mysql 分页语句Limit用法

  1. create procedure XiaoZhengGe   
  2. @sqlstr nvarchar(4000), --查询字符串   
  3. @currentpage int--第N页   
  4. @pagesize int --每页行数   
  5. as   
  6. set nocount on   
  7. declare @P1 int--P1是游标的id   
  8. @rowcount int   
  9. exec sp_cursoropen @P1 output,@sqlstr,@scrollopt=1,@ccopt=1,@rowcount=@rowcount output   
  10. select ceiling(1.0*@rowcount/@pagesize) as 总页数--,@rowcount as 总行数,@currentpage as 当前页   
  11. set @currentpage=(@currentpage-1)*@pagesize+1   
  12. exec sp_cursorfetch @P1,16,@currentpage,@pagesize   
  13. exec sp_cursorclose @P1   
  14. set nocount off   
  

其它的方案:如果没有主键,可以用临时表,也可以用方案三做,但是效率会低。 

建议优化的时候,加上主键和索引,查询效率会提高。 

 

通过SQL 查询分析器,显示比较:我的结论是: 

分页方案二:(利用ID大于多少和SELECT TOP分页)效率最高,需要拼接SQL语句 

分页方案一:(利用Not In和SELECT TOP分页) 效率次之,需要拼接SQL语句 

分页方案三:(利用SQL的游标存储过程分页) 效率最差,但是最为通用 

 

在实际情况中,要具体分析。 

 

【引用:在SQL Server中通过SQL语句实现分页查询 】

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

mysql用户和数据库的关系 mysql用户和数据库的关系 Apr 08, 2025 pm 07:15 PM

MySQL 数据库中,用户和数据库的关系通过权限和表定义。用户拥有用户名和密码,用于访问数据库。权限通过 GRANT 命令授予,而表由 CREATE TABLE 命令创建。要建立用户和数据库之间的关系,需创建数据库、创建用户,然后授予权限。

mysql 是否要付费 mysql 是否要付费 Apr 08, 2025 pm 05:36 PM

MySQL 有免费的社区版和收费的企业版。社区版可免费使用和修改,但支持有限,适合稳定性要求不高、技术能力强的应用。企业版提供全面商业支持,适合需要稳定可靠、高性能数据库且愿意为支持买单的应用。选择版本时考虑的因素包括应用关键性、预算和技术技能。没有完美的选项,只有最合适的方案,需根据具体情况谨慎选择。

RDS MySQL 与 Redshift 零 ETL 集成 RDS MySQL 与 Redshift 零 ETL 集成 Apr 08, 2025 pm 07:06 PM

数据集成简化:AmazonRDSMySQL与Redshift的零ETL集成高效的数据集成是数据驱动型组织的核心。传统的ETL(提取、转换、加载)流程复杂且耗时,尤其是在将数据库(例如AmazonRDSMySQL)与数据仓库(例如Redshift)集成时。然而,AWS提供的零ETL集成方案彻底改变了这一现状,为从RDSMySQL到Redshift的数据迁移提供了简化、近乎实时的解决方案。本文将深入探讨RDSMySQL零ETL与Redshift集成,阐述其工作原理以及为数据工程师和开发者带来的优势。

如何针对高负载应用程序优化 MySQL 性能? 如何针对高负载应用程序优化 MySQL 性能? Apr 08, 2025 pm 06:03 PM

MySQL数据库性能优化指南在资源密集型应用中,MySQL数据库扮演着至关重要的角色,负责管理海量事务。然而,随着应用规模的扩大,数据库性能瓶颈往往成为制约因素。本文将探讨一系列行之有效的MySQL性能优化策略,确保您的应用在高负载下依然保持高效响应。我们将结合实际案例,深入讲解索引、查询优化、数据库设计以及缓存等关键技术。1.数据库架构设计优化合理的数据库架构是MySQL性能优化的基石。以下是一些核心原则:选择合适的数据类型选择最小的、符合需求的数据类型,既能节省存储空间,又能提升数据处理速度

MySQL 中的查询优化对于提高数据库性能至关重要,尤其是在处理大型数据集时 MySQL 中的查询优化对于提高数据库性能至关重要,尤其是在处理大型数据集时 Apr 08, 2025 pm 07:12 PM

1.使用正确的索引索引通过减少扫描的数据量来加速数据检索select*fromemployeeswherelast_name='smith';如果多次查询表的某一列,则为该列创建索引如果您或您的应用根据条件需要来自多个列的数据,则创建复合索引2.避免选择*仅选择那些需要的列,如果您选择所有不需要的列,这只会消耗更多的服务器内存并导致服务器在高负载或频率时间下变慢例如,您的表包含诸如created_at和updated_at以及时间戳之类的列,然后避免选择*,因为它们在正常情况下不需要低效查询se

mysql怎么查看 mysql怎么查看 Apr 08, 2025 pm 07:21 PM

通过以下命令查看 MySQL 数据库:连接到服务器:mysql -u 用户名 -p 密码运行 SHOW DATABASES; 命令获取所有现有数据库选择数据库:USE 数据库名;查看表:SHOW TABLES;查看表结构:DESCRIBE 表名;查看数据:SELECT * FROM 表名;

了解 ACID 属性:可靠数据库的支柱 了解 ACID 属性:可靠数据库的支柱 Apr 08, 2025 pm 06:33 PM

数据库ACID属性详解ACID属性是确保数据库事务可靠性和一致性的一组规则。它们规定了数据库系统处理事务的方式,即使在系统崩溃、电源中断或多用户并发访问的情况下,也能保证数据的完整性和准确性。ACID属性概述原子性(Atomicity):事务被视为一个不可分割的单元。任何部分失败,整个事务回滚,数据库不保留任何更改。例如,银行转账,如果从一个账户扣款但未向另一个账户加款,则整个操作撤销。begintransaction;updateaccountssetbalance=balance-100wh

mysql用户名和密码怎么填 mysql用户名和密码怎么填 Apr 08, 2025 pm 07:09 PM

要填写 MySQL 用户名和密码,请:1. 确定用户名和密码;2. 连接到数据库;3. 使用用户名和密码执行查询和命令。

See all articles