位置: 编程技术 - 正文

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

  • 金税四期怎么查账
  • 员工自己全额承担社保可以在个税申报吗
  • 个人所得税申报退税多久到账
  • 通过公账直接转账可以吗
  • 什么不属于损益类的会计项目
  • 付款给对方的会计分录
  • 计税金额是含税还是不含税
  • 租借车辆发生事故后的保险理赔问题
  • 企业与政府土地合作开发模式
  • 养殖企业如何做销售
  • 办理外汇账户开户手续
  • 有差价的商品发票如何开具及注意事项
  • 出口货物的进项发票什么时候认证
  • 自己生产的产品用于职工福利
  • 已审核已过账已经生成凭证还能修改吗?
  • 员工销售家具取得的工资怎么写分录?
  • 支付房屋租金计入什么会计科目
  • 收了款未开票凭证如何做
  • 过路费去年的票还可以用吗
  • 房租合同印花税的计税依据怎么算
  • 税控盘抵扣政策依据
  • 应交税费算什么费用
  • 销售商品会计凭证
  • 职工发放洗漱用品怎么进行财税处理?
  • 什么情况下的发烧才会全身酸痛呢
  • 小微企业核定征收所得税税率
  • 公司基本户没开影响报税吗
  • 企业账户利息收入怎么算
  • 咨询公司怎么交社保
  • 成本少结转了怎么调账
  • 3联收据
  • mac应用程序安装权限在哪找
  • 如何设置bios开关机
  • 以固定资产换入无形资产
  • 购入固定资产后海通融资怎么办
  • 跨年度坏账准备转回账务处理
  • hptlbxfx.exe
  • php stat
  • 没有收入的情况下可以填成本吗
  • php获取上个月第一天
  • uni-app list
  • 备用金需要发票吗?收据可以报销吗
  • YOLOv5网络结构组成
  • 销售费用可以开专票吗
  • php session用法
  • 外籍专家劳务费
  • 企业所得税核查报告
  • 工会经费月月都缴纳吗?
  • 帝国cms简介标签
  • 辅助核算内容不完整
  • 其他应付款贷方表示什么意思
  • 车辆保险费如何缴纳印花税的
  • 代开运输发票会不会造成重复征税?
  • 速动比率和流动比率的关系
  • 残保金是第二年交前一年的吗
  • 分公司非独立核算企业所得税税率
  • 小微企业取得的进项税能不能抵扣
  • mysql全部语法
  • sql语句错误提示
  • 光标很粗怎么弄细
  • Mac上Parallels Desktop共享虚拟机怎么设置 Mac上Parallels Desktop共享虚拟机设置步
  • calctool
  • mac上播放器
  • hpdskflt.sys
  • linux常用命令 cat
  • windows8怎么装
  • linker command failed with exit code 1 (use -v to see invocation)
  • unity3d怎么编程
  • 如何使用maven
  • perl读取文件内容逐行处理
  • shell 数组变量
  • 批处理查找字符中含有等号的子串
  • python3并发
  • python中运算符重载方法
  • javascript怎么用
  • 使用筷子就餐会不会传染乙肝病毒
  • android开发从入门到精通(项目案例版)
  • 用python编写的程序称为
  • 运输类税点
  • 异辛烷征收消费税对成品油影响
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设