mysql查询一个订单表 按照状态来排序 怎么写 -1永远排最后 2排最前
状态 status 订单状态 -1撤销 0待付款1待接单2待操作3待审核4已审核5待好评6已好评 7完成 待操作永远是排最前 然后撤销的永远排最后 然后其他状态按照正常的升序来排 这样的排序
顺晟科技
2021-07-07 13:32:25
68
原文链接:何晓东 博客
算是一道常见的面试题引来的,有些大厂也喜欢把这个题当做面试题。
题目:例如有一个 1g 的文件,里面存放这乱序不的数字,如果利用 100m 完成整体排序?
思路就是:先将大文件逐行读取,每 10000 行为一组,然后排序后写入文件中,文件名称类似 t1.txt, t2.txt ... 这样的名称,直至读取和拆分完毕整个文件,然后遍历所有文件,每个文件先读取行,放入临时排序数组,然后取其中最小值,放入临时存储数组,同时记录索引位置,从对应文件中取下一个数字,放入当前索引中,然后继续重复这样的操作,直到所有文件的所有内容读取完毕,临时排序数组也读取完毕,则整体文件重新排序完毕。
以下是一个 PHP 多路归并排序 demo 代码,只是简单的骨架结构,例如 min 取最小值部分,可以扩展成定长最小堆实现,或者优先队列,能保存值和所在文件就行。
PHP 多路归并 demo 代码:
function multiWaySort()
{
// 读取所有的文件描述符
$fds = [];
$dir = scandir('./runtime/txt/');
foreach ($dir as $file) {
if ($file != '.' && $file != '..') {
$fds[] = fopen('./runtime/txt/' . $file, 'rb');
}
}
// 读取每个文件的行内容,放入临时排序数组
$tmpNums = [];
foreach ($fds as $fd) {
$tmpNums[] = (int)fgets($fd);
}
$nums = [];
$count = 0;
while (true) {
if (empty($tmpNums)) break;
// 最小值放入临时存储数组
$value = min($tmpNums);
$nums[] = $value;
// 读取最小值所在索引,对应的文件下一行内容
$idx = array_search($value, $tmpNums);
$next = fgets($fds[$idx]);
if (!$next) {
unset($tmpNums[$idx]);
unset($fds[$idx]);
} else {
$tmpNums[$idx] = (int)$next;
}
// 临时存储数组到达一定数量追加写入文件一次
if (count($nums) == 20) {
foreach ($nums as $value) {
$f = fopen('./runtime/result.txt', 'ab+');
fwrite($f, $value . PHP_EOL);
}
$nums = [];
}
if ($count == 4999999) {
continue;
}
$count++;
}
}
参考链接:
大文件排序/外存排序问题实战 k 路归并排序最后恰饭 阿里云全系列产品/短信包特惠购买 中小企业上云更佳选择 阿里云内部优惠券
15
2022-09
03
2021-10
07
2021-07