位置: 编程技术 - 正文

深入分析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)

  • 航天信息开票软件
  • 完税价格是含税价格吗?
  • 季报需要注意什么
  • 过路费抵扣进项税填在申报表哪里
  • 去税务局开增值税专用发票需要缴费吗
  • 个人名字的发票专用章
  • 收到应收账款逾期短信
  • 税收分类编码不可用是什么原因
  • 支票结算业务流程
  • 预算控制方法主要包括
  • 企业购入办公桌和办公椅的核算
  • 电汇凭证如何使用
  • 抵扣上月留抵税额的分录
  • 工程结算与工程施工
  • 公司给个人买的意外险个人有权利查吗
  • 退役士兵增值税优惠申报方法
  • 租房修缮费扣除
  • 研发费用归集会计分录
  • 没有购销合同怎么申报印花税
  • 什么是留存收益项目
  • 委外加工费用会计分录
  • bios设置教程视频
  • 支付人工费会计科目
  • 涉税服务实务重点总结
  • 设备经营租赁属于什么行业
  • nfcmp3
  • 减值测试的资产有哪些
  • 客户抽奖活动方案
  • 商业连锁企业有哪些
  • 罚款属于应付账款吗
  • v-model的双向绑定原理
  • 第一季度季初资产总额和第一季度季末同一个数吗
  • 文化体育用品批发城有哪些
  • 实战到底究竟是什么意思啊
  • web自动化测试平台
  • Vue3通透教程【十三】TS简单类型详解
  • 来料加工成品如何入库
  • 电子回单是什么样子
  • 电子承兑逾期超过30天怎么办
  • 处置固定资产净收益属于利得吗
  • 金融企业买入返还股票
  • 车辆购置税能否融资租赁
  • access分组计数
  • sql server基本知识
  • 结转成本类账户及税金及附加到本年利润
  • 公司欲购买一台设备,现在一次性
  • 医院哪些地方需要有明显的禁烟标识
  • 共管账户取钱需要多久到账
  • 转出未交增值税年末怎么转平
  • 暂估入库做账
  • 开发成本贷方负数表示什么
  • 初级会计现值的计算
  • 销售自己使用过的物品免税吗
  • 利润总额与应纳税所得额的差异国内动态
  • 日记账的建立
  • 产品成本核算有多条原则和要求
  • mysql handshake
  • sqlgun
  • mysql5.7.26启动失败
  • Python3.6-MySql中插入文件路径,丢失反斜杠的解决方法
  • mac 邮箱
  • gwservice进程
  • windows运行.sh
  • linux ifcon
  • hyper-v以后安装操作系统
  • ubuntu怎么设置成中文
  • neotrace.exe - neotrace是什么进程 有什么用
  • win7 64位旗舰版电脑如何取消网页自动保存密码?win7取消自动保存网页密码的方法
  • linux查内存信息
  • 详细的收藏
  • linux开机启动进程
  • 批处理系统的进程调度算法
  • js圆形链
  • javascript构成
  • python3 random模块
  • 异步promise原理
  • javascript如何禁用
  • jquery中on
  • 纳税人识别号和公司税号一样吗
  • 开票信息哪里查询
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设