mysql 排序num_MySQL 实现row_number() 分组排序功能

数据库基本脚本

CREATE TABLE `a` (

`ID` INT(10) NULL DEFAULT NULL,

`class` INT(10) NULL DEFAULT NULL,

`score` INT(10) NULL DEFAULT NULL

)

COLLATE='utf8_general_ci'

ENGINE=InnoDB;

insert into a values (1,1,110);

insert into a values (2,1,120);

insert into a values (3,1,130);

insert into a values (4,1,140);

insert into a values (5,2,210);

insert into a values (6,2,220);

insert into a values (7,2,230);

insert into a values (8,2,240);

insert into a values (9,3,310);

insert into a values (10,3,320);

insert into a values (11,4,410);

1. 对 class进行分组 取每组的前2条

select id,class,score,rank from (

select b.id,b.class,b.score,@rownum:=@rownum+1 ,

if(@pdept=b.class,@rank:=@rank+1,@rank:=1) as rank,

@pdept:=b.class

from (

select id,class,score from a order by id

) b ,(select @rownum :=0 , @pdept := null ,@rank:=0) c ) result

having rank <3 ;

rank <3 指的相当月ruwnum<3 每组都自动给上了序号.多少条记录就多少个序号.指的是每组的.

2.  对 class 进行分组   取记录满足两天的,也就是rownum=2 的数据

select id,class,score,rank from (

select b.id,b.class,b.score,@rownum:=@rownum+1 ,

if(@pdept=b.class,@rank:=@rank+1,@rank:=1) as rank,

@pdept:=b.class

from (

select id,class,score from a order by score desc

) b ,(select @rownum :=0 , @pdept := null ,@rank:=0) c ) result

having rank =2 ;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/467627.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Netty源码学习(零)前言

本系列文章将介绍Netty的工作机制&#xff0c;以及分析Netty的主要源码。 基于的版本是4.1.15.Final&#xff08;2017.08.24发布&#xff09; 水平有限&#xff0c;如有谬误请留言指正 参考资料 the_flash的简书 占小狼的简书 转载于:https://www.cnblogs.com/stevenczp/p/7571…

要想选到音质好的耳机,你应该需要知道这些~

最近在一个音频公司调试我们设备的音频&#xff0c;从这次调试中&#xff0c;有所收获&#xff0c;希望这次的吹牛大家看完后&#xff0c;以后去买音频产品&#xff0c;可以分辨什么是好的&#xff0c;什么是不好的。有些产品硬件没有问题&#xff0c;但是产品经理因为个人喜好…

mysql kafka binlog_为什么使用kafka处理mysql binlog?

在开发 Spark Streaming 的公共组件过程中&#xff0c;需要将 binlog 的数据(Array[Byte])转换为 Json 格式&#xff0c;供用户使用&#xff0c;本文提供一种转换的思路。另外我们会用到几个辅助类&#xff0c;为了行文流畅&#xff0c;我们将辅助类的定义放在文章的最后面。如…

Fantasia (Tarjan+树形DP)

Time Limit: 1000 ms Memory Limit: 256 MB Description 给定一张N个点、M条边的无向图 $G$ 。每个点有个权值Wi。 我们定义 $G_i$ 为图 $G$ 中删除第 $i$ 号顶点后的图。我们想计算 $G_1, G_2, ..., G_n$ 这N张图的权值。 对于任意一张图 $G$ &#xff0c;它的权值是这样定义…

买书这件事

知识这种东西&#xff0c;你只有不断的补充才不会觉得匮乏&#xff0c;我每年都会买点书&#xff0c;我喜欢买书&#xff0c;但是却不看书&#xff0c;很多书籍我都是当成工具书来用。我记得在2015年的时候&#xff0c;我需要自己写专利&#xff0c;但是我对写专利这个事情一窍…

python logging mysql_Python 操作 MySQL 的正确姿势

欢迎大家关注腾讯云技术社区-博客园官方主页&#xff0c;我们将持续在博客园为大家推荐技术精品文章哦~作者&#xff1a;邵建永使用Python进行MySQL的库主要有三个&#xff0c;Python-MySQL(更熟悉的名字可能是MySQLdb)&#xff0c;PyMySQL和SQLAlchemy。Python-MySQL资格最老&…

Linus Torvalds的最新电脑配置

大家好&#xff0c;祝大家6.1节日快乐最近Linus Torvalds 公布了他的电脑配置&#xff0c;有了这个配置清单之后&#xff0c;每个人都可以拥有一台和Linux之父一样的电脑&#xff0c;当你拥有了一台之后&#xff0c;你可以发个朋友圈&#xff0c;「我今天用Linus 的电脑解了一个…

马上就校招了,是要去实习还是复习?

昨天晚上&#xff0c;遇到一个特别纠结的同学&#xff0c;他现在收到一份实习的通知&#xff0c;他犹豫是要去实习呢还是继续在学校复习学习技术。实习的话可以增加自己校招的筹码&#xff0c;比如在和面试官侃大山的时候&#xff0c;可以把实习这件事情拿出来说&#xff0c;这…

mysql order by 索引名字_MySQL如何利用索引优化ORDER BY排序语句

MySQL索引通常是被用于提高WHERE条件的数据行匹配或者执行联结操作时匹配其它表的数据行的搜索速度。MySQL也能利用索引来快速地执行ORDER BY和GROUP BY语句的排序和分组操作。通过索引优化来实现MySQL的ORDER BY语句优化&#xff1a;1、ORDER BY的索引优化。如果一个SQL语句形…

YAML/Properties配置文件与Spring Boot(转)

多年来&#xff0c;Java开发人员依赖于属性文件或xml文件来指定应用程序配置。在企业应用程序中&#xff0c;人们可以为每个环境&#xff08;如开发&#xff0c;分段和生产&#xff09;创建单独的文件&#xff0c;以定义相应环境的属性。但是&#xff0c;通过Spring引导&#x…

嵌入式杂谈之makefile补充

我看了下自己的文章库存&#xff0c;好像还没有一篇关于Makefile的文章&#xff0c;所以这篇刚好可以弥补自己的缺失。makefile预定义变量预定义变量即系统自带的变量预定义变量作用AR库文件维护程序的名称&#xff0c;默认为arAS汇编程序的名称&#xff0c;默认为asCCc编译器的…

Weex 解决Print: Entry, :CFBundleIdentifier, Does Not Exist 错误方法

一、原因 导致这个错误的原因是我们的/user/你的用户名/.rncache文件中 boost_1_63_0.tar.gz文件内容不完整导致 如果你也玩过React-native框架&#xff0c;在0.45版本之后也会出现这个错误。 解决方法&#xff1a; 1、重新下载一个boost_1_63_0.tar.gz文件&#xff0c;替换它&…

mysql表单查询_表单查询实例

[TOC]### 1.查找部门30中员工的详细信息。select * from emp where deptno 30;### 2.找出从事clerk工作的员工的编号、姓名、部门号。select empno,ename,deptno from emp where job clerk;### 3.检索出奖金多于基本工资的员工信息。select * from emp where comm > sal;#…

安卓9.0马达框架分析

前言最近需要将之前的一些驱动接口转为安卓标准接口&#xff0c;方便上层应用或者第三方应用去适配。这篇文章先从简单的马达框架入手进行讲解。正文整个马达框架比较简单&#xff0c;安卓官方已经帮我们实现了framework到HAL层&#xff0c;我们需要实现的就只有驱动层。这篇文…

PYQT4 Python GUI 编写与 打包.exe程序

工作中需要开发一个小工具&#xff0c;简单的UI界面可以很好的提高工具的实用性&#xff0c;由此开启了我的第一次GUI开发之旅&#xff0c;下面将自己学习的心得记录一下&#xff0c;也做为学习笔记吧&#xff01;&#xff01;&#xff01; 参考&#xff1a;http://www.qaulau.…

在MySQL中以下属于ddl语句的_ddl语言(以下哪些命令是ddl语句)

DDL一般指数据定义语言。数据库模式定义语言DDL(Data Definition Language)&#xff0c;是用于描述数据库中要存储的现实世界实体的语言。常见的DDL语句&#xff1a;创建数据库.dml触发器 就是普通的 insert / update / delete 触发器。ddl触发器 就是一些特有的 ddl 语句的触发…

你知道嵌入式,那你看过这个吗?

大家好&#xff0c;因为最近各种原因&#xff0c;我身边的很多同事都转行摆地摊了&#xff0c;可能因为那是一份自由的职业&#xff0c;摆地摊可以从事的范围很广&#xff0c;也不用起早贪黑了&#xff0c;而且收入并不低。也是因为这样&#xff0c;很多嵌入式方面的岗位越来越…

mysql把select结果存到变量中_mysql实例 select into保存到变量的例子

本节继续分享mysql中使用select into保存查询结果到变量中的实例。代码&#xff1a;mysql>mysql> CREATE TABLE Employee( //创建雇员表-> id int,-> first_name VARCHAR(15),-> last_name VARCHAR(15),-> start_date DATE,-> end_date DATE,-> salary…

mvc一对多模型表单的快速构建

功能需求描述 Q:在实际的开发中&#xff0c;经常会遇到一个模型中包含有多个条目的表单。如何将数据提交到后台&#xff1f; A: 以数组的形式提交到后台就Ok了(真的那么简单么&#xff0c;如果再嵌套一层呢&#xff1f;) A2&#xff1a;拆分多个模型&#xff0c;映射就没啥问题…

asp删除mysql_asp php 清空access mysql mssql数据库的代码

1、ASP清空ACCESSDim Rs,ConnSet ConnServer.CreateObject("Adodb.Connection")Conn.Open "ProviderMicrosoft.Jet.OLEDB.4.0;Data Source"&server.mappath("readlog.mdb")Set RsConn.OpenSchema(20)Do While not Rs.EofIf Ucase(Rs("T…