位置: 编程技术 - 正文

8种MySQL分页方法总结(mysql分页怎么实现)

编辑:rootadmin

推荐整理分享8种MySQL分页方法总结(mysql分页怎么实现),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql分页怎么实现,mysql是怎么分页的,mysql分页的几种方式,mysql的三种分页方法,mysql分页方式,mysql分页怎么实现,mysql分页的几种方式,mysql分页怎么实现,内容如对您有帮助,希望把文章链接给更多的朋友!

MySQL的分页似乎一直是个问题,有什么优化方法吗?网上看到网上推荐了一些分页方法,但似乎不太可行,你能点评一下吗?

方法1: 直接使用数据库提供的SQL语句

---语句样式: MySQL中,可用如下方法: SELECT * FROM 表名称 LIMIT M,N。

---适应场景: 适用于数据量较少的情况(元组百/千级)。

---原因/缺点: 全表扫描,速度会很慢 且 有的数据库结果集返回不稳定(如某次返回1,2,3,另外的一次返回2,1,3)。Limit限制的是从结果集的M位置处取出N条输出,其余抛弃。

方法2: 建立主键或唯一索引, 利用索引(假设每页条)

---语句样式: MySQL中,可用如下方法:---适应场景: 适用于数据量多的情况(元组数上万)。

---原因: 索引扫描,速度会很快。有朋友提出因为数据查询出来并不是按照pk_id排序的,所以会有漏掉数据的情况,只能方法3。

方法3: 基于索引再排序

---语句样式: MySQL中,可用如下方法: SELECT * FROM 表名称 WHERE id_pk > (pageNum*) ORDER BY id_pk ASC LIMIT M。

---适应场景: 适用于数据量多的情况(元组数上万). 最好ORDER BY后的列对象是主键或唯一所以,使得ORDERBY操作能利用索引被消除但结果集是稳定的(稳定的含义,参见方法1)。

---原因: 索引扫描,速度会很快. 但MySQL的排序操作,只有ASC没有DESC(DESC是假的,未来会做真正的DESC,期待)。

8种MySQL分页方法总结(mysql分页怎么实现)

方法4: 基于索引使用prepare(第一个问号表示pageNum,第二个?表示每页元组数)

---语句样式: MySQL中,可用如下方法:---适应场景: 大数据量。

---原因: 索引扫描,速度会很快. prepare语句又比一般的查询语句快一点。

方法5:利用MySQL支持ORDER操作可以利用索引快速定位部分元组,避免全表扫描

---比如: 读第到行元组(pk是主键/唯一键)。方法6: 利用"子查询/连接+索引"快速定位元组的位置,然后再读取元组. 道理同方法5

---如(id是主键/唯一键,蓝色字体时变量):

利用子查询示例:利用连接示例:方法7: 存储过程类(最好融合上述方法5/6)

---语句样式: 不再给出

---适应场景: 大数据量. 作者推荐的方法

---原因: 把操作封装在服务器,相对更快一些。

方法8: 反面方法

---网上有人写使用 SQL_CALC_FOUND_ROWS。 没有道理,勿模仿 。

基本上,可以推广到所有数据库,道理是一样的。但方法5未必能推广到其他数据库,推广的前提是,其他数据库支持ORDER BY操作可以利用索引直接完成排序。

mysql配置模板(my-*.cnf)参数详细说明 mysql安装成功后有几个默认的配置模板,列表如下:my-huge.cnf:用于高端产品服务器,包括1到2GBRAM,主要运行mysqlmy-innodb-heavy-4G.ini:用于只有innodb的安装

CentOS下php使用.0.0.1不能连接mysql的解决方法 php代码很简单:$server=".0.0.1";println("Begin");$link=mysql_connect($server,"mysql","mysql");if(!$link){die('Couldnotconnect:'.mysql_error().mysql_errno());}linux本机下使用phpmysql.php

MySQL ERROR (HY)错误解决方法 当通过TCP/IP连接MySQL远程主机时,出现ERROR(HY):LostconnectiontoMySQLserverat'readinginitialcommunicationpacket',systemerror:。如果是在linuxshell命令行中直接打mysql

标签: mysql分页怎么实现

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

上一篇:Mysql字符串字段判断是否包含某个字符串的2种方法(mysql字符串字段数据类型)

下一篇:mysql配置模板(my-*.cnf)参数详细说明(mysql配置怎么调出来)

  • 企业要本地迁往隔壁县区,税务要注销吗
  • 小规模纳税人补税怎么补
  • 国外酒店打印的住宿单可以入账吗
  • 生产成本里面的直接人工
  • 房地产开发企业会计科目
  • 出口货物当期免抵退税不得免征和抵扣税额,应计入
  • 免税即征即退先征后退
  • 小企业汇算清缴所得税分录
  • 汽车道路救援费用多少
  • 自己生产的产品用于职工福利
  • 政府专项补助购置固定资产进项税可以抵扣吗?
  • 预售房提前还款需要去解押吗
  • 房地产增值税预征率
  • 小规模纳税人的认定标准是什么
  • 已认证的发票如何冲红
  • 加油费开的专用发票可以用来抵扣企业所得税吗
  • 营改增后增值税科目
  • 损失性费用的会计科目有
  • 预收款转营业外收入要交增值税吗
  • 实收资本减少会不会变相影响注册资本金
  • 建安企业外地项目预缴增值税
  • 个人所得税合并申报
  • 对方开的销项负数抵扣联怎么处理
  • 农民工签订劳务合同的条件
  • 如何设置电脑任务栏显示
  • windows11怎么创建宽带拨号连接图标
  • 外购的形式
  • 收到棚户区改造资金
  • 使用Huagepage和PGO来提升PHP7的执行性能
  • 拍卖土地印花税
  • php可以和iis配合运行吗?
  • 如何提高php性能
  • 材料暂估入账
  • vue如何配置环境变量
  • 退休后工作单位填什么内容
  • 菲律宾薄荷岛疫情最新消息
  • php数组的概念是什么
  • php trim函数
  • 已确认的发票如何入账
  • opencv怎么训练
  • java开源二次开发平台
  • IndexError: invalid index of a 0-dim tensor. Use `tensor.item()` in Python
  • 查看ls命令的使用手册
  • 所得税包含哪些项目
  • 金税盘怎么写入发票
  • 帝国cms使用手册
  • 玩转mongodb4.0从入门到实践
  • 银行存款对账方法
  • 销售清单需要盖什么章子
  • ERROR CODE: 1175 YOU ARE USING SAFE UPDATE MODE AN
  • 微信,支付宝等第三方支付对货币的影响
  • 增值税普通发票税率
  • 管理费用包括哪些部门
  • 员工的交通费发票可以报销嘛
  • 驾校挂靠车辆账务处理是?
  • 收到跨年的发票怎么入账
  • 人力资源外包服务平台
  • 购买的材料入库属于什么会计科目
  • 法人借给公司钱怎么写情况说明
  • 个别会计报表和合并会计报表
  • 关于端午节福利发放的通知(通知公告)
  • 所得税费用怎么计提
  • 个体工商户个税2023最新政策
  • mysql免安装版本
  • mac如何隐藏桌面
  • award bios设置图解教程
  • linux网络管理及应用
  • centos如何清除硬盘数据
  • linux shell命令大全
  • win8.1安装应用商店
  • 新闻客户端手机版下载
  • android2d游戏开发
  • js随机生成数
  • js实现计数
  • Metaio in Unity3d 教学--- 四.再谈谈图片扫描之tracking配置文件
  • public services翻译
  • 安卓开发 内存
  • javascript图片
  • jquery修改css
  • 电子普通发票怎么查验真伪
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设