您的位置:首页 > 数据库

使用数据库排序or使用具体编程语言排序

2016-10-21 22:12 204 查看
原文地址:点击打开链接






问:请提供一些必须在MySQL中排序的实例?

答:在PHP中执行排序更优的情况举例如下:

数据源不在MySQL中,存在硬盘、内存或者来自网络的请求等;
数据存在MySQL中,量不大,而且没有相应的索引,此时把数据取出来用PHP排序更快;
数据源来自于多个MySQL服务器,此时从多个MySQL中取出数据,然后在PHP中排序更快;
除了MySQL之外,存在其他数据源,比如硬盘、内存或者来自网络的请求等,此时不适合把这些数据存入MySQL后再排序。
必须在MySQL中排序的实例如下:

MySQL中已经存在这个排序的索引;
MySQL中数据量较大,而结果集需要其中很小的一个子集,比如1000000行数据,取TOP10;
对于一次排序、多次调用的情况,比如统计聚合的情形,可以提供给不同的服务使用,那么在MySQL中排序是首选的。另外,对于数据深度挖掘,通常做法是在应用层做完排序等复杂操作,把结果存入MySQL即可,便于多次使用。
不论数据源来自哪里,当数据量大到一定的规模后,由于占用内存/Cache的关系,不再适合PHP中排序了;此时把数据复制、导入或者存在MySQL,并用INDEX优化,是优于PHP的。不过,用Java,甚至C++来处理这类操作会更好。



内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  数据库
相关文章推荐