数据库中排序的对比及使用条件详解


Posted in PHP onFebruary 23, 2012

假定MySQL服务器和PHP服务器都已经按照最适合的方式来配置,那么系统的可伸缩性(Scalability)和用户感知性能(User-perceived Performance)是我们追求的主要目标。在实际运行中,MYSQL 中数据往往以 HASH tables、BTREE 等方式存贮于内存,操作速度很快;同时INDEX 已经进行了一些预排序;很多应用中,MySQL 排序是首选。

PHP与MySQL相比具有如下优势:

1、考虑整个网站的可伸缩性和整体性能,在应用层(PHP)中排序明显会降低数据库的负载,从而提升整个网站的扩展能力。而数据库的排序,实际上成本是非常高的,消耗内存、CPU,如果并发的排序很多,DB 很容易到瓶颈。

2、如果在应用层(PHP)和MYSQL之间还存在数据中间层,合理利用,PHP会有更好的收益。

3、PHP在内存中的数据结构专门针对具体应用来设计,比数据库更为简洁、高效;

4、PHP不用考虑数据灾难恢复问题,可以减少这部分的操作损耗;

5、PHP不存在表的锁定问题;

6、MySQL中排序,请求和结果返回还需要通过网络连接来进行,而PHP中排序之后就可以直接返回了,减少了网络IO。

至于执行速度,差异应该不会很大,除非应用设计有问题,造成大量不必要的网络IO。另外,应用层要注意PHP 的 Cache 设置,如果超出会报告内部错误;此时要根据应用做好评估,或者调整Cache。具体选择,将取决于具体的应用。

列出一些PHP中执行排序更优的情况:

1、数据源不在MySQL 中,存在硬盘、内存或者来自网络的请求等;

2、数据存在 MySQL 中,量不大,而且没有相应的索引,此时把数据取出来用PHP排序更快;

3、数据源来自于多个MySQL 服务器,此时从多个 MySQL 中取出数据,然后在PHP中排序更快;

4、除了MySQL 之外,存在其他数据源,比如硬盘、内存或者来自网络的请求等,此时不适合把这些数据存入MySQL 后再排序;

列出一些必须在MySQL中排序的实例:

1、MySQL中已经存在这个排序的索引;

2、MySQL中数据量较大,而结果集需要其中很小的一个子集;比如 1000000 行数据,取TOP 10;

3、对于一次排序、多次调用的情况,比如统计聚合的情形,可以提供给不同的服务使用,那么在MySQL 中排序是首选的。另外,对于数据深度挖掘,通常做法是在应用层做完排序等复杂操作,把结果存入MySQL即可,便于多次使用。

4、不论数据源来自哪里,当数据量大到一定的规模后,由于占用内存/Cache 的关系,不再适合PHP中排序了;此时把数据复制、导入或者存在MySQL ,并用INDEX 优化,是优于PHP 的。不过,用 Java,甚至 C++ 来处理这类操作会更好。 有些类似大数据集聚合或者汇总的数据,在客户端排序得不偿失。当然,也有用类似搜索引擎的思路来解决类似应用的情况。

从网站整体考虑,就必须加入人力和成本的考虑。假如网站规模和负载较小,而人力有限(人数和能力都可能有限),此时在应用层(PHP)做排序要做不少开发和调试工作,耗费时间,得不偿失;不如在DB 中处理,简单快速。对于大规模的网站,电力、服务器的费用很高,在系统架构上精打细算,可以节约大量的费用,是公司持续发展之必要;此时如果能在应用层(PHP) 进行排序并满足业务需求,尽量在应用层进行。

关于PHP中执行排序与MySQL中执行排序的相关知识就介绍到这里了,希望本次的介绍能够对您有所收获!

PHP 相关文章推荐
PHP在字符断点处截断文字的实现代码
Apr 21 PHP
PHP 第二节 数据类型之数组
Apr 28 PHP
如何使用php绘制在图片上的正余弦曲线
Jun 08 PHP
深入php中var_dump方法的使用详解
Jun 24 PHP
关于JSON以及JSON在PHP中的应用技巧
Nov 27 PHP
PHP中IP地址与整型数字互相转换详解
Aug 20 PHP
ci检测是ajax还是页面post提交数据的方法
Nov 10 PHP
为百度UE编辑器上传图片添加水印功能
Apr 16 PHP
PHP数组游标实现对数组的各种操作详解
Jan 26 PHP
PHP实现动态获取函数参数的方法示例
Apr 02 PHP
PHP中$GLOBALS与global的区别详解
Mar 21 PHP
PHP控制循环操作的时间
Apr 01 PHP
PHP中几个常用的魔术常量
Feb 23 #PHP
PHP教程之PHP中shell脚本的使用方法分享
Feb 23 #PHP
php tp验证表单与自动填充函数代码
Feb 22 #PHP
PHP 设计模式之观察者模式介绍
Feb 22 #PHP
php模拟post行为代码总结(POST方式不是绝对安全)
Feb 22 #PHP
用穿越火线快速入门php面向对象
Feb 22 #PHP
php重定向的三种方法分享
Feb 22 #PHP
You might like
php数组函数序列之array_unique() - 去除数组中重复的元素值
2011/10/29 PHP
php在apache环境下实现gzip配置方法
2015/04/02 PHP
IE与FireFox的兼容性问题分析
2007/04/22 Javascript
3分钟写出来的Jquery版checkbox全选反选功能
2013/10/23 Javascript
深入理解JavaScript系列(22):S.O.L.I.D五大原则之依赖倒置原则DIP详解
2015/03/05 Javascript
详解js数组的完全随机排列算法
2016/12/16 Javascript
JS将unicode码转中文方法
2017/05/08 Javascript
JS 使用 window对象的print方法实现分页打印功能
2018/05/16 Javascript
详解vuex状态管理模式
2018/11/01 Javascript
layDate插件设置开始和结束时间
2018/11/15 Javascript
layui的表单提交以及验证和修改弹框的实例
2019/09/09 Javascript
基于js实现的图片拖拽排序源码实例
2020/11/04 Javascript
Python 调用DLL操作抄表机
2009/01/12 Python
详细解读Python中的__init__()方法
2015/05/02 Python
Python cookbook(字符串与文本)针对任意多的分隔符拆分字符串操作示例
2018/04/19 Python
python for 循环获取index索引的方法
2019/02/01 Python
python操作openpyxl导出Excel 设置单元格格式及合并处理代码实例
2019/08/27 Python
Python matplotlib读取excel数据并用for循环画多个子图subplot操作
2020/07/14 Python
Pytorch框架实现mnist手写库识别(与tensorflow对比)
2020/07/20 Python
Python爬虫之爬取淘女郎照片示例详解
2020/07/28 Python
纯CSS和jQuery实现的在页面顶部显示的进度条效果2例(仿手机浏览器进度条效果)
2014/04/16 HTML / CSS
Sneaker Studio波兰:购买运动鞋
2018/04/28 全球购物
医学专业大学生求职的自我评价
2013/11/27 职场文书
七年级地理教学反思
2014/01/26 职场文书
小学中秋节活动方案
2014/02/06 职场文书
大四自我鉴定
2014/02/08 职场文书
高中生学期学习自我评价
2014/02/24 职场文书
2014年道德讲堂实施方案
2014/03/05 职场文书
高级工程师英文求职信
2014/03/19 职场文书
详细的本科生职业生涯规划范文
2014/09/16 职场文书
高三英语复习计划
2015/01/19 职场文书
对公司的意见和建议
2015/06/04 职场文书
教师法制教育培训学习心得体会
2016/01/14 职场文书
班组长如何制订适合本班组的工作计划?
2019/07/10 职场文书
处世之道:关于真诚相待的名言推荐
2019/12/02 职场文书
Vue鼠标滚轮滚动切换路由效果的实现方法
2021/08/04 Vue.js