位置: 编程技术 - 正文

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配置怎么调出来)

  • 全国增值税发票查询平台 手机版
  • 个体工商户核定征收
  • 汇算清缴期间费用填表说明
  • 零售环节征收消费税标准
  • 机票抵扣进项税怎么填申报表
  • 事业单位固定资产计提折旧是当月还是次月
  • 差额征税小规模免征增值税
  • 公司汽车上牌费入什么科目
  • 一般纳税人外地预缴增值税税率
  • 成品油跨月发票红字冲销步骤
  • 发生哪些情形的应判定为重大电力安全隐患
  • 资源税征税范围有哪些
  • 结转损益类收入科目的余额其中主营业务收入
  • 个税专项附加扣除是每个月扣还是按年计算
  • 汇算清缴需要准备哪些数据
  • 公司注销时有大额应付款如何做账务处理合适?
  • 银行承兑汇票到期日后多久可以承兑
  • 银行手续费发票怎么开
  • 预缴增值税转入流程
  • 行政单位办公室主任必须是党员吗
  • 红冲的普票要给对方单位吗
  • 旅行社开哪里比较好
  • 法律关系三要素表
  • 普通发票电子发票没有章
  • 如何查询进项发票是否作废
  • 税控信息表
  • 软件企业两免三减半税收政策到期
  • 纳税人签章填什么
  • 适用差额征税的小规模纳税人有哪些
  • 保险公司赔偿计入营业外收入
  • 资本公积转增资本个人股东是否纳税
  • 分公司交总公司管理费怎么做账
  • 银行票据都有哪些
  • 现金流量表怎么做
  • 哪些行业需要缴纳水利建设基金
  • PRISMSTA.EXE - PRISMSTA是什么进程 有什么用
  • 财务期初期末
  • 预付账款属于资产类
  • 成本转入费用
  • linux系统中的文件访问权限包括几种
  • 购买办公用品是否缴纳印花税
  • 受托方代收代缴的消费税计入成本吗
  • 贷款的账务处理
  • laravel 5异常错误:FatalErrorException in Handler.php line 38的解决
  • javascript移动鼠标
  • 固定资产处理步骤
  • thinkphp表单验证
  • 小程序uniapp怎么用
  • 企业所得税中哪些属于免税收入
  • 上年科目记错如何更正
  • 刷pos机的如何记会计分录
  • 房地产公司测绘费怎么做会计分录
  • 售后回租融资租赁会计处理
  • 营业总收入同比增长怎么分析
  • 已核准未登记名称我可以注册吗
  • 公司房租发票是法人名字能入账吗安全吗
  • 补报印花税税需要提供什么材料
  • 融资租赁固定资产不属于筹资活动
  • 调表不调账都有什么情况
  • 发工资用个人账户还是公司帐户
  • 支付补偿款计入什么会计科目
  • 资金信息综合服务
  • 应收账款有什么
  • 个人借款产生的利息怎么计算的
  • 应纳税所得额收入总额包括
  • 以前年度调整
  • mysql字符串类型有哪些
  • win7旗舰版系统激活码
  • 虚拟机怎么手动设置ip地址
  • centos6.5无法启动
  • korok是什么文件
  • win10wifi总是掉线
  • win7使用临时配置文件登录
  • linux在u盘中运行
  • linux挂载啥意思
  • Android游戏开发书籍
  • vue如何用
  • jq中attr用法
  • 广州电子税务局财务报表在哪里查询
  • 采购设备税率多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设