位置: 编程技术 - 正文

mysql 分页优化解析(mysql分页优化原理)

编辑:rootadmin
如果你的数据量有几十万条,用户又搜索一些很通俗的词,然后要依次读最后几页重温旧梦。mysql该很悲壮的不停操作硬盘。 所以,可以试着让mysql也存储分页,当然要程序配合。(这里只是提出一个设想,欢迎大家一起讨论) ASP的分页:在ASP系统中有Recordset对象来实现分页,但是大量数据放在内存中,而且不知道什么时候才失效(请ASP高手指点). SQL数据库分页:用存储过程+游标方式分页,具体实现原理不是很清楚,设想如果用一次查询就得到需要的结果,或者是id集,需要后续页时只要按照结果中的IDs读出相关记录。这样只要很小的空间保留本次查询的所有IDs. (SQL中的查询结果不知道怎样清楚过期垃圾?) 这样,可以让mysql模拟存储分页机制: 1. select id from $table where $condition order by $field limit $max_pages*$count;查询符合条件的IDs.限定最大符合条件的记录数量,也可以不加。 2. 因为php在执行结束后所有变量都要lost,所以可以考虑:方案a. 在mysql建立临时表,查询结果用一个时间或随机数作为唯一标志插入。其中建立page1~pagen个字段,每个字段保存该页中需要的ids, 这样一个id对一条记录.方案b. 如果打开session,也可以放在session中保存,实际上是放在文件中保存。建立一个$IDs数组,$IDs[1]~$IDs[$max_pages]. 考虑到有时候用户会开几个窗口同时查询,要为$ids做一个唯一标志,避免查询结果相互覆盖。二维数组和$$var都是好办法。 3. 在每页页的请求中,直接找到对应的IDs,中间以","间隔:select * from $table where id in ($ids); 速度绝对快 4. 收尾要考虑查询结果的自动清除,可以设置定时或者按比例随机清楚。如果用mysql临时表要加上一个时间标志字段,session中要加入$IDs["time"]=time(); 在一定时间以后不操作视为过期数据。 5. 如果要优化,可以考虑用把1和2.a中的语句合并成select ...... into .... Note:1.以上只是针对mysql的修补方案,希望mysql哪天能把这些功能加进去2.其它数据库也可以套用。3.如果其它数据库还有更先进的分页方式,请告诉我或mailto: steeven@kali.com.cn4.如果真的有很多数据要查询,还是和mysql再见吧,sql,oracle都提供了更先进的关键词索引查询。 精益求精,以上只是抛砖引玉,欢迎共同探讨分页问题。(也可关于其它数据库)希望有一天能把各种分页方式整理出来供新手参考。

推荐整理分享mysql 分页优化解析(mysql分页优化原理),希望有所帮助,仅作参考,欢迎阅读内容。

mysql 分页优化解析(mysql分页优化原理)

文章相关热门搜索词:mysql 高效分页,mysql 高效分页,mysql uuid分页优化,mysql 分页越来越慢的原理,mysql 分页越来越慢的原理,mysql分页性能优化,mysql uuid分页优化,mysql uuid分页优化,内容如对您有帮助,希望把文章链接给更多的朋友!

同时运行多个MySQL服务器的方法 如果你想要运行多个服务器,最容易的方法是用不同的TCP/IP端口和套接字文件重新编译服务器,因此他们不是侦听同一个TCP/IP端口或套接字。假设一个

mysql主从服务器同步心得体会第1/2页 原来看过MYSQL同步数据的实现,可是自己还没有动过手,今天没什么事就玩一玩,正好在旁边有另一台空电脑,都在同一个路由器下。哈哈,正好。不

删除mysql数据库中的重复数据记录 采用的是下面的方法可删除,假设重复的是test数据库中的title字段createtablebakas(select*fromtestgroupbytitlehavingcount(*)=1);insertintobak(select*fromtestgroupbytitlehavingcount(

标签: mysql分页优化原理

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

上一篇:MySQL Replace INTO的使用

下一篇:同时运行多个MySQL服务器的方法

  • 什么是简易征税项目
  • 计提存货跌价准备的存货出售
  • 公司自有房产自用要交房产税吗
  • 企业注销库存怎么做账
  • 怎么报企业所得税季报
  • 咨询服务费的印花税率
  • 资本溢价是
  • 支付专家劳务费什么意思
  • 餐费专票认证了怎么办
  • 没有业务来往可以报税吗
  • 学校有没有纳税人识别号
  • 成本/利润
  • 企业的税收筹划
  • 销售商品发生的业务招待费计入什么科目
  • 机动车抵扣联是什么
  • c盘文件详解
  • win10电脑和win7电脑怎么共享文件
  • 认筹金客户经常提出哪些问题
  • c++ 库文件
  • winds10企业版
  • 公司注销不清算可以吗
  • fbembed.dll
  • excel多表操作法
  • 国有资产无偿划转协议
  • 中央公园商场
  • 使用电子计算机生成的会计凭证
  • 利润表里的所得税费用怎么算出来的
  • cjzc框架
  • bootstrapicon
  • /ncrc命令
  • 建行企业网上银行主管盾权限分配
  • 企业收到微信和微信消息
  • phpcms 标签
  • 企业向合伙企业转让股权
  • 收到抵扣发票怎么做分录
  • ps索引工具怎么用
  • 福利费用使用范围
  • 综合保税区可以随便进出吗
  • 会计六大类会计科目
  • 开专用发票可以直接写加工费这个明细吗?
  • 现金流量表季度期初现金余额怎么填
  • 现金日记账一般采用数量金额式
  • 软件开发过程付什么费用
  • 客户给的现金如何转到公司账上
  • 什么是补偿性余额,对银行借款的成本有何影响?
  • 行政单位年终奖的相关发放规定
  • 收到的赔款罚款怎么做账
  • 生产性生物资产折旧计入什么科目
  • 什么是收入?企业有哪些
  • 固定资产卡片录入日期怎么改
  • 其他资本公积核算哪些内容
  • 营业收入的核算内容包括
  • sqlserver怎么创建临时表
  • win7桌面右键菜单设置
  • 监控iphone软件
  • efi shell有什么用
  • apache服务器配置与使用工作笔记
  • 鼠标点击关闭按钮没反应
  • linux引导和启动
  • macbook 苹果系统
  • pop3是什么意思中文
  • linux对比文件夹差异
  • win7睡眠设置在哪
  • win7网络正常但是所有浏览器网页打不开
  • win7 64纯净版网页打开出现乱码该怎么办 解决方法介绍
  • cocos2d教程
  • opengl mfc
  • Cocos2dx3.2 Crazy Tetris 基本设置及主菜单页面(菜单、按钮)
  • unity游戏人物选择
  • js的事件绑定
  • Linux中删除文件夹的正确方式
  • Node.js中的事件循环是什么
  • python sftp put
  • 简述JavaScript中全局变量与局部变量的作用域
  • python开发的程序怎么运行
  • 基于android开发
  • javascript中this的用法
  • JQuery绑定事件的函数是
  • 车船税完税凭证去哪里打印
  • 深圳拖欠工资举报网站
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设