位置: 编程技术 - 正文

深入分析Mysql中limit的用法(mysql深入解析)

编辑:rootadmin

推荐整理分享深入分析Mysql中limit的用法(mysql深入解析),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql深入理解,mysql深度解析,mysql深入理解,mysql的lsn,mysqlmgr深入理解,mysqlmgr深入理解,mysqlmgr深入理解,mysql深入理解,内容如对您有帮助,希望把文章链接给更多的朋友!

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

SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offsetLIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。初始记录行的偏移量是 0(而不是 1): 为了与 PostgreSQL 兼容,MySQL 也支持句法: LIMIT # OFFSET #。mysql> SELECT * FROM table LIMIT 5,; // 检索记录行 6-//为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1: mysql> SELECT * FROM table LIMIT ,-1; // 检索记录行 -last.//如果只给定一个参数,它表示返回最大的记录行数目: mysql> SELECT * FROM table LIMIT 5; //检索前 5 个记录行//换句话说,LIMIT n 等价于 LIMIT 0,n。注意limit 和limit 9,1的不同:例如:1.

2.

同样是取条后条记录,第1句快还是第2句快&#;第1句是先取了前条记录,取其中最大一个ID值作为起始标识,然后利用它可以快速定位下条记录第2句择是仅仅取条记录后1条,然后取ID值作起始标识定位下条记录第1句执行结果. rows in set (0.) sec第2句执行结果. rows in set (0.) sec其实第2句完全可以简化成:

直接利用第条记录的ID,不用经过Max运算,这样做理论上效率因该高一些,但在实际使用中几乎看不到效果,因为本身定位ID返回的就是1条记录,Max几乎不用运作就能得到结果,但这样写更清淅明朗,省去了画蛇那一足.

但不管是实现方式是存贮过程还是直接代码中,瓶颈始终在于MS-SQL的TOP总是要返回前N个记录,这种情况在数据量不大时感受不深,但如果成百上千万,效率肯定会低下的.相比之下MySQL的limit就有优势的多,执行:

的结果分别是:

深入分析Mysql中limit的用法(mysql深入解析)

rows in set (0.) sec1 row in set (0.) sec

而MS-SQL只能用Select Top ID From cyclopedia 执行时间是ms,执行同样的操作时间也不及MySQL的ms.limit的offset(偏移量)用于记录较多的时候,记录较少时,偏移offset较小,直接使用limit较优。offset越大,后者越优。

1、offset比较小的时候。

多次运行,时间保持在0.-0.之间

多次运行,时间保持在0.-0.之间,主要是0.结论:偏移offset较小的时候,直接使用limit较优。这个显示是子查询的原因。

2、offset大的时候。

select * from yanxue8_visit limit ,多次运行,时间保持在0.左右

多次运行,时间保持在0.左右,只有前者的1/3。可以预先offset越大,后者越优。mysql> SELECT * FROM table LIMIT ,-1; // 检索记录行 -last. //如果只给定一个参数,它表示返回最大的记录行数目

以上所述就是本文的全部内容了,希望大家能够喜欢。

请您花一点时间将文章分享给您的朋友或者留下评论。我们将会由衷感谢您的支持!

MySQL之终端Terminal(dos界面)管理数据库、数据表、数据的基本操作 MySQL有很多的可视化管理工具,比如mysql-workbench和sequel-pro-。现在我写MySQL的终端命令操作的文章,是想强化一下自己对于MySQL的理解,总会比使用图形化

多种不同的 MySQL 的 SSL 配置 在这篇博客的帖子里,我将会描述不同的使用MySQL数据库的SSL配置方法。SSL给了你什么你可以通过互联网使用MySQL复制特性(replication)或者通过互联网

MySQL服务器连接过程浅析 mysqld是MySQL服务器端主进程,可以说mysqld是MySQL的真正核心,一切工作都是围绕mysqld进程进行的。所以要解剖mysql这个庞然大物,mysqld的代码是最好的突

标签: mysql深入解析

本文链接地址:https://www.jiuchutong.com/biancheng/347283.html 转载请保留说明!

上一篇:浅谈mysql的中文乱码问题(mysql数据库中文)

下一篇:MySQL之终端Terminal(dos界面)管理数据库、数据表、数据的基本操作(终端运行mysql)

  • 开发票,对方收取税点,如何计算
  • 出差飞机票报销标准
  • 销售部的招待费计入什么费用
  • 服务不动产扣除项目怎么填
  • 国内增值税专用发票造假第一大案
  • 实收资本记账凭证摘要怎么写
  • 临时员工和正式员工区别
  • 运输业务增值税
  • 存货跌价准备转销会影响当期损益吗
  • 公司接待考察团需要准备什么
  • 企业替员工缴纳商保家财险
  • 没有税收编码的发票怎么开具红字票
  • 代账报税软件哪个好
  • 合同作废合同
  • 2021年个体工商户的税率是多少
  • 外购商品对外赠送增值税怎么算
  • 企业所得税减免税额计算公式
  • 应交税费待抵扣进项税额是什么科目
  • 应税劳务、服务清单
  • 房屋契税怎样计算公式
  • 工程结算收入以前年度多结转收入怎么处理?
  • win11和win10比较
  • 差错更正未来适用法
  • 企业出现销售折扣时如何处理
  • 如何在Windows 11上卸载更新
  • php红包源码
  • 事业单位投资收回账务处理
  • 多交的增值税可以做营业外支出吗?
  • mce文件是什么软件
  • 收取包装物押金税率
  • 外资企业出租房产税优惠
  • mongodb4.0安装教程
  • 生产经营个人所得税速算扣除数表
  • 工程结算结算gbq文件怎么做
  • cvpr2020结果
  • 增值税补交还有没有责任
  • 会计中财务费用为负
  • 营业外收支的账户是什么
  • php 清除缓存
  • sqlserver2008误操作数据
  • mysql备份方式有哪些
  • 两处取得收入,如何进行个税的申报?
  • 呆账核销账务处理程序
  • 小规模没有税控怎么开普票
  • 企业净利率多少算高
  • 人工成本的分类是
  • 累计折旧的账务处理
  • 小规模纳税人销售商品会计分录
  • 美容院收入怎么做会计分录
  • 应付职工薪酬和生产成本的区别
  • 税盘进项税额怎么做
  • 建筑业老项目和新项目如何计税
  • 债权人和债务人的区别
  • 商业承兑汇票贴现流程
  • 投资收益科目在利润表中怎么填
  • 车辆使用费报销制度
  • 营改增一般纳税人标准
  • 五险一金的正确说法
  • 出租车票没有发票怎么办
  • sql判断字段是否有某个值
  • ubuntu虚拟机怎么改用户名
  • linux文件一般放哪里
  • linux html编辑器
  • node.js入门教程
  • Android游戏开发实践指南
  • [置顶]游戏名:chivalry2
  • python erf
  • shell实现的实验步骤
  • python中面向对象的概念
  • android基础知识点
  • js中substring和substr有区别吗
  • python的redis
  • python字典常用操作以及字典的嵌套
  • 2020年上海税务跨区迁移很麻烦吗
  • 企业不做审计会有什么后果?
  • 国税纳税申报表打印
  • 转让土地的土地增值税
  • 青海国税局官网
  • 华为领导班子成员名单
  • 哪个部门负责药品检验
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设