首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL 分组排序后 → 如何N条或倒数N条

N条或倒数N条   我们回到标题,分组排序后,如何N条记录或倒数N条记录   循环查数据库   1、先批量查询 task_id   2、再根据 task_id 逐个去查 t_task_exec_log...,排序获取N条记录   3、最后进行一个数据汇合,封装成页面需要的数据格式   但这种方式会循环查数据库,一般是被禁止的   GROUP BY 结合 MySQL 函数   1、先批量查询 task_id...关于窗口函数可查阅官方文档:Window Functions,不做过多介绍   我们用 ROW_NUMBER 来实现 N条或倒数N条   1、批量查询 task_id   2、使用 ROW_NUMBER...,N条或倒数N条   第一条   结果如下    5 条 SELECT * from ( SELECT *, ROW_NUMBER() OVER(PARTITION BY task_id...再看 GROUP BY 结合 MySQL 函数   我们仔细看看 GROUP BY 结合 MySQL 函数 倒数 5 条的结果   我们发现和窗口函数的倒数 5 条的结果不一致   那到底是哪种方式不对

1.3K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql分组最大(最小、最新、N条)条记录

    在数据库开发过程中,我们要为每种类型的数据取出几条记录,或者是最新、最小、最大等等,这个该如何实现呢,本文章向大家介绍如何实现mysql分组最大(最小、最新、N条)条记录。...5, 'b5'); 数据表如下: name val memo a 2 a2 a 1 a1 a 3 a3 b 1 b1 b 3 b3 b 2 b2 b 4 b4 b 5 b5 按name分组val...按name分组val最小的值所在行的数据 方法一: select a.* from tb a where val = (select min(val) from tb where name = a.name...name = a.name and val < a.val) order by a.name 以上五种方法运行的结果均为如下所示: name val memo a 1 a1 b 1 b1 按name分组第一次出现的行所在的数据...tb a where val = (select top 1 val from tb where name = a.name) order by a.name //这个是sql server的 //mysql

    9.2K30

    排序算法():基数排序

    基数排序也可以称为多关键字排序,同计数排序类似,也是一种非比较性质的排序算法。将待排序集合中的每个元素拆分为多个总容量空间较小的对象,对每个对象执行桶排序后,则完成排序过程。...而桶排序又是一种对元素总容量敏感的排序算法,所以存在使用限制。 基数排序过程中也使用了桶排序操作,不过对于桶排序面向的对象进行了优化。...演示示例 待排序集合为:[1086, 187, 30, 76, 0, 1359, 36, 777, 9, 2] step 1: 因为此处选择的待排序集合元素类型为进制整数,所以基数为 10,申请的桶个数为...将桶中所有元素移动回原始序列后,序列为:[30, 0, 2, 1086, 76, 36, 187, 777, 1359, 9] 重复执行 step 2 和 step 3: circle 1: 当位数 值为 2 时,根据元素位数字...算法过程中需要申请的空间大小为 ,其中 表示待排序元素的基数,例如示例中的进制整数排序,则 ;若待排序元素为字符串,则 ,因为基数的容量空间总是有限的,所以算法的时间复杂度为 。

    1.2K10

    排序算法 () ---简单选择排序

    工作原理: 首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。...n个记录的直接选择排序可经过n-1趟直接选择排序得到有序结果。...具体算法描述如下: 初始状态:无序区为R[1…n],有序区为空; 第i趟排序(i=1,2,3…n-1)开始时,当前有序区和无序区分别为R[1…i-1]和R(i…n)。...该趟排序从当前无序区中-选出关键字最小的记录 R[k],将它与无序区的第1个记录R交换,使R[1…i]和R[i+1…n)分别变为记录个数增加1个的新有序区和记录个数减少1个的新无序区; n-1趟结束,数组有序化了...稳定性: 但是简单选择排序是不稳定的 譬如:{2, 2, 1, 3} , 最终是{1, 2`, 2, 3} 可以发现2和2`位置前后发生置换。

    34220

    算法(二)初等排序

    前言 排序是算法的基础,排序有很多种方法,有些方法实现起来很简单,但是效率较差,我们可以将这些排序的方法称之为初等排序。这篇文章我们就来学习初等排序中的插入排序和冒泡排序。...图解插入排序 插入排序过程中会将需要排序的数组,分为两个部分:已排序部分和未排序部分,如下图所示。 ?...插入的排序规则: 将开头元素视为以排序部分。接着执行如下的处理,直到没有未排序部分。 - 取出未排序部分的开头元素赋值给临时保存数据的变量v。...图解冒泡排序 与插入排序一样,需要进行冒泡排序的数组也分为已排序部分和未排序部分。...经过第三轮排序,已排序部分的元素为1、2、3。 第四轮排序: ?

    58190

    排序之冒泡排序

    冒泡排序作为排序之一,是一种简单且稳定的排序算法 算法思想可以联想为向湖中下石头和较轻的石头变成泡泡上浮的过程 想象每一块石头处在相应的高度,从上往下相邻两个石头进行比较,较大的石头往下沉,替代下一石头的位置...因此,排序至多需要 n-1 趟(最后一趟只剩一个元素,因此不会再排序),最少需要1趟(已经有序) 算法思想:双重for循环,外层循环控制每次排序元素的长度(被排序的元素个数依次递减),内层循环遍历每轮循环的元素...时间复杂度:O(n^2)       空间复杂度:O(1) 代码实现:(未优化版) package com.gxwz.vo; import java.util.Arrays; /** * Java排序之冒泡排序..., 24, 26, 49, 100] [0, 2, 9, 10, 16, 24, 26, 49, 100] 优化版: import java.util.Arrays; /** * Java排序之冒泡排序...A[j+1] = temp; flag = false; } } if(flag) break; } return A; } } 优化思路: 在每次循环设置一个

    22730

    排序方法

    希尔排序(Shell Sort) 原理:是插入排序的一种更高效的改进版本,也称为缩小增量排序,是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。...for (j = 0; j < n-i-1; j++) { // 内层循环控制每次遍历需要比较的次数 if (arr[j] > arr[j+1]) { // 如果一个元素大于后一个元素...然后,它使用两个嵌套的循环来进行排序。外层循环控制遍历的次数,而内层循环则负责每次遍历时的元素比较和可能的交换。如果一个元素大于后一个元素,则交换它们的位置。...然而,通过随机化基准元素的选择或使用三数中等技巧,可以大大降低最坏情况发生的概率。...稳定排序:计数排序是稳定的排序算法,即相等的元素在排序后保持原有的顺序。

    8910

    排序

    目录 1、冒泡排序(Bubble Sort) 2、选择排序(Selection Sort) 3、插入排序(Insertion Sort) 4、希尔排序(Shell Sort) 5、归并排序(Merge...Sort) 11、 总 结 首先排序算法可以分为内部排序算法和外部排序算法:在内存中进行的称为内部排序算法,也就是这里所说的这种算法;相应的,当数据量很大时无法全部拷贝到内存需要使用外存,称为外部排序算法...接下来我们可用如下表来简单概括这种算法: 大经典排序算法 平均时间复杂度 最好时间复杂度 最坏时间复杂度 空间复杂度 排序方式 稳定性 冒泡排序 O \OmicronO(n2) O \OmicronO...该排序算法可分为如下所示的两大类 比较类排序:通过比较来决定元素间的相对次序,由于其时间复杂度不能突破O(nlog ⁡ \loglogn),因此也称为非线性时间比较类排序。...(Selection Sort) 算法步驟 首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置; 再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾; 重复第2步,直到所有元素均排序完毕

    28540
    领券