查询topn的另一种方法通过orderby排序后利用limit来实现

2024-02-09 05:38

本文主要是介绍查询topn的另一种方法通过orderby排序后利用limit来实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录
前言
1、热身题实践
其他
前言
一直有个想法:把面试需要的知识点全都总结一下,包括数据库,语言,算法,数据结构等知识,形成一个面试总结笔记,这样以后面试的时候只看这些文章回顾下就行了。今天就先总结下Mysql的面试热身题吧,后续会总结其他方面的点。当然,文章同样会不定时更新。

1、热身题实践
说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句。
问题及描述:
–1.学生表
Student(S#,Sname,Sage,Ssex) --S# 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别
–2.课程表
Course(C#,Cname,T#) --C# --课程编号,Cname 课程名称,T# 教师编号
–3.教师表
Teacher(T#,Tname) --T# 教师编号,Tname 教师姓名
–4.成绩表
SC(S#,C#,score) --S# 学生编号,C# 课程编号,score 分数
*/
–创建测试数据
create table student(sno varchar(10),sname varchar(10),sage datetime,ssex varchar(10));
insert into student values(‘01’ , ‘赵雷’ , ‘1990-01-01’ , ‘男’);
insert into student values(‘02’ , ‘钱电’ , ‘1990-12-21’ , ‘男’);
insert into student values(‘03’ , ‘孙风’ , ‘1990-05-20’ , ‘男’);
insert into student values(‘04’ , ‘李云’ , ‘1990-08-06’ , ‘男’);
insert into student values(‘05’ , ‘周梅’ , ‘1991-12-01’ , ‘女’);
insert into student values(‘06’ , ‘吴兰’ , ‘1992-03-01’ , ‘女’);
insert into student values(‘07’ , ‘郑竹’ , ‘1989-07-01’ , ‘女’);
insert into student values(‘08’ , ‘王菊’ , ‘1990-01-20’ , ‘女’);

create table course(cno varchar(10),cname varchar(10),tno varchar(10));
insert into course values(‘01’ , ‘语文’ , ‘02’);
insert into course values(‘02’ , ‘数学’ , ‘01’);
insert into course values(‘03’ , ‘英语’ , ‘03’);

create table teacher(tno varchar(10),tname varchar(10));
insert into teacher values(‘01’ , ‘张三’);
insert into teacher values(‘02’ , ‘李四’);
insert into teacher values(‘03’ , ‘王五’);

create table sc(sno varchar(10),cno varchar(10),score int(4));
insert into sc values(‘01’ , ‘01’ , 80);
insert into sc values(‘01’ , ‘02’ , 90);
insert into sc values(‘01’ , ‘03’ , 99);
insert into sc values(‘02’ , ‘01’ , 70);
insert into sc values(‘02’ , ‘02’ , 60);
insert into sc values(‘02’ , ‘03’ , 80);
insert into sc values(‘03’ , ‘01’ , 80);
insert into sc values(‘03’ , ‘02’ , 80);
insert into sc values(‘03’ , ‘03’ , 80);
insert into sc values(‘04’ , ‘01’ , 50);
insert into sc values(‘04’ , ‘02’ , 30);
insert into sc values(‘04’ , ‘03’ , 20);
insert into sc values(‘05’ , ‘01’ , 76);
insert into sc values(‘05’ , ‘02’ , 87);
insert into sc values(‘06’ , ‘01’ , 31);
insert into sc values(‘06’ , ‘03’ , 34);
insert into sc values(‘07’ , ‘02’ , 89);
insert into sc values(‘07’ , ‘03’ , 98);
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
1、查询"01"课程比"02"课程成绩高的学生的信息及课程分数

方法一:连表查询
SELECT *
FROM student s
LEFT JOIN sc on s.sno=sc.sno
LEFT JOIN sc sc1 on s.sno=sc1.sno
WHERE sc.cno=‘01’
and sc1.cno=‘02’
and sc.score>sc1.score
方法二:形成子表然后再连表查询
select a.S# from
(select s#,score from SC where C#=‘001’) a,
(select s#,score from SC where C#=‘002’) b
where a.score>b.score
and a.s#=b.s#;(注意子查询的使用场景)
方式三:
注意:限制条件添加join条件中对左表没有约束!左表没有被限制条件限制!
SELECT *
FROM student s
LEFT join sc on s.Sno=sc.Sno and sc.cno=‘01’
LEFT join sc sc1 on s.Sno=sc1.Sno and sc1.cno=‘02’
WHERE sc.score>sc1.score
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
2、查询同时存在"01"课程和"02"课程的情况

SELECT *
FROM student s
LEFT join sc on s.Sno=sc.Sno and sc.cno=‘01’
LEFT join sc sc1 on s.Sno=sc1.Sno and sc1.cno=‘02’
WHERE sc.score is not NULL and sc1.score is not null
1
2
3
4
5
3、查询平均成绩大于等于60分的同学的学生编号和学生姓名和平均成绩

SELECT s.sno,s.sname,avg(sc.score)
FROM student s
LEFT join sc on s.sno=sc.sno
GROUP BY s.sno
HAVING avg(sc.score)>=60
ORDER BY avg(sc.score) desc
1
2
3
4
5
6
4、查询在sc表存在成绩的学生信息的SQL语句。

SELECT * FROM Student s
LEFT JOIN SC on s.Sno=SC.Sno
GROUP BY s.Sno
HAVING count(score)>0
1
2
3
4
5、查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩

SELECT s.Sno , Sname, count(Cno),sum(score)
from Student s left join SC on s.Sno=SC.Sno
GROUP BY s.Sno
1
2
3
6、查询"李"姓老师的数量

SELECT count(*) FROM Teacher t WHERE t.Tname LIKE ‘李%’
1
7、查询学过"张三"老师授课的同学的信息

方法一:连表查询
SELECT *
FROM student s
LEFT join sc on s.sno=sc.sno
left join course c on c.cno=sc.cno
LEFT join teacher t on c.tno=t.tno
WHERE t.tname=“张三”
方法二:利用子查询
SELECT sname,sno
FROM student
WHERE sno in
(SELECT distinct sno
FROM sc
WHERE cno in(
SELECT c.cno
FROM course c
LEFT JOIN teacher t on c.tno=t.tno
WHERE t.tname=‘张三’))
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
8、查询没学过"张三"老师授课的同学的信息

#注意子查询的使用场景
SELECT * FROM Student WHERE Sno not in
(SELECT s.Sno FROM
Student s LEFT join SC on s.Sno=SC.Sno
LEFT join Course c on SC.Cno=c.Cno
LEFT join Teacher t on c.Tno=t.Tno
WHERE t.Tname = ‘张三’)
1
2
3
4
5
6
7
9、查询学过编号为"01"但是没有学过编号为"02"的课程的同学的信息

方法一:连表查询
SELECT DISTINCT s.sno,s.sname
FROM student s
LEFT JOIN sc on s.sno = sc.sno
LEFT JOIN sc s1 on s1.sno=s.sno
WHERE sc.cno=‘01’
and s1.cno!=‘02’
方法二: #注意子查询的灵活使用
SELECT s.*
FROM student s
LEFT join sc on s.sno=sc.sno
WHERE sc.cno=‘01’
and s.sno in
(SELECT DISTINCT s1.sno
FROM student s1
LEFT join sc sc1 on s1.sno=sc1.sno
WHERE sc1.cno!=“02”
)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
10、查询没有学全所有课程的同学的信息

SELECT s.*
FROM Student s
LEFT join SC on s.Sno=SC.Sno
GROUP BY s.Sno
HAVING count(Cno)<
(select count(C#) from SC)
#注意group by之后是对相应的属性做限制,之后将满足限制的所有数据筛选出来(分成多少组有多少数据)
1
2
3
4
5
6
7
11、查询至少有一门课与学号为"01"的同学所学相同的同学的信息

SELECT DISTINCT student.sno,sname
FROM student
LEFT JOIN sc on student.sno=sc.sno
WHERE sc.cno in
(SELECT cno
FROM sc
WHERE sno=‘01’)
and sc.sno!=‘01’
1
2
3
4
5
6
7
8
12、查询两门及其以上不及格课程的同学的学号,姓名及其平均成绩

#注意不能在where子句中限制组函数如:where max(score)>60
SELECT sc.sno,sname,avg(score)
FROM student s
LEFT JOIN sc on s.sno=sc.sno
WHERE sc.score<60
GROUP BY sc.sno
HAVING count(*)>=2
1
2
3
4
5
6
7
13、检索"01"课程分数小于60,按分数降序排列的学生信息

SELECT *
FROM student s LEFT JOIN sc
on s.sno=sc.sno
WHERE sc.cno=‘01’
and sc.score<60
ORDER BY score desc
1
2
3
4
5
6
14、查询每门课程被选修的学生数

SELECT cno,count(sno)
FROM sc
GROUP BY cno
1
2
3
15、查询出只有两门课程的全部学生的学号和姓名

SELECT s.sno,sname
FROM student s LEFT JOIN sc
on s.sno=sc.sno
GROUP BY s.sno
HAVING count(*)=2
1
2
3
4
5
16、查询1990年出生的学生名单

SELECT s.*
FROM Student s
WHERE s.Sage BETWEEN’1990-01-01’ and ‘1990-12-31’
1
2
3
17、查询每门课程的平均成绩,结果按平均成绩降序排列,平均成绩相同时,按课程编号升序排列

SELECT cno,avg(score)
FROM sc
GROUP BY cno
ORDER BY avg(score) desc,cno asc
1
2
3
4
18、查询任何一门课程成绩在70分以上的姓名、课程名称和分数。

SELECT s.sname,c.cname,score
FROM student s LEFT join sc
on s.sno=sc.sno
LEFT JOIN course c
on sc.cno=c.cno
GROUP BY s.sno
HAVING min(score)>=70
1
2
3
4
5
6
7
19、查询选修"张三"老师所授课程的学生中,成绩最高的学生信息及其成绩

SELECT s1.*,score
FROM student s1 LEFT JOIN sc
on s1.sno=sc.sno
WHERE sc.cno in(
SELECT c.cno
FROM teacher t LEFT JOIN course c
on t.tno=c.tno
WHERE t.tname=“张三”)
ORDER BY score desc
LIMIT 1
1
2
3
4
5
6
7
8
9
10
20、查询不同课程成绩相同的学生的学生编号、课程编号、学生成绩

 SELECT DISTINCT sc.cno,sc.score,sc.snoFROM sc LEFT join sc sc1on sc.sno=sc1.snoWHERE sc.cno!=sc1.cnoand sc.score=sc1.score

1
2
3
4
5
21、查询各科成绩最好的前两/三名#重点注意

方法一:连表查询(重点参考)
SELECT *
FROM sc a
LEFT join sc b on a.cno=b.cno and a.score<b.score#筛选我的成绩比别人的成绩差的数据
GROUP BY a.cno,a.sno
HAVING count(1)<2#如果我的成绩比别人的成绩差的数据条数小于2,也就代表有0或1个人的成绩比我好,则对应的用户就被筛选出来了
直观的意义是取分组后的TOPN,实际操作时候,只能是从每组里面取第一条数据,只是利用多重分组来将满足条件的TopN条数据给筛选出来而已!

#方法二:使用子查询
SELECT s1.*
FROM SC s1
WHERE
( SELECT COUNT(1)
FROM SC s2
WHERE s1.Cno=s2.Cno
AND s2.score>=s1.score
)<=2
ORDER BY s1.Cno,s1.score DESC
分析下这个sql:
select * from test1 a where 2 > (select count() from test1 where course=a.course and score>a.score)
相关子查询的特点就是子查询依赖与外部查询,在这里面其实是 select * from test 已经先执行了一遍了,查出了所有的数据
然后相关子查询针对每一行数据进行select count(
) from test1 where course=a.course and score>a.score
例如:
  第一行是张三,数学77,那么相关子查询做的工作就是找出test表所有课程是数学的行,查询 张三,77|李四,68|王五,99
  然后where条件score>77,查询出王五,99,count=1,这时候外部条件2>1,符合。
  第二行是李四,数学68,那么相关子查询做的工作就是找出test表所有课程是数学的行,查询 张三,77|李四,68|王五,99
  然后where条件score>68,查询出张三,77,王五,99,count=2,这时候外部条件2>2,不符合。
  第三行是王五,数学99,那么相关子查询做的工作就是找出test表所有课程是数学的行,查询 张三,77|李四,68|王五,99
  然后where条件score>99,没有数据,这时候外部条件2>0,符合。
  那么就筛选出了数学最大的2个人,张三和王五。
其实这里的子查询就是找出和当前行类型能匹配上的比他大的有多少,没有比他大的他就是最大
那么找top1就是 1>(xxx),topN就是N>(xxxxx)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#以下几个题目要了解下子查询在select字段时的原理
22、查询各科成绩最高分、最低分和平均分:以如下形式显示:课程ID,课程name,最高分,最低分,平均分,及格率,中等率,优良率,优秀率
–及格为>=60,中等为:70-80,优良为:80-90,优秀为:>=90

SELECT sc.cno as “课程ID”,c.cname as “课程name”,
max(sc.score) as “最高分”,min(sc.score) as “最低分”,avg(sc.score) as “平均分”,
CAST(((select count(1) from sc s WHERE s.cno=sc.cno and score>=60)*100/(select count(1) from sc s WHERE s.cno=sc.cno)) as DECIMAL(18,2)) as “及格率”,
cast((select count(1) from sc where cno = c.cno and score >= 60)*100.0 / (select count(1) from sc where cno = c.cno) as decimal(18,2)) as “[及格率(%)]”
FROM sc
LEFT JOIN course c on sc.cno=c.cno
GROUP BY sc.cno
#这里的s指的就是外表s按照sql的执行顺序,从from到where->group by->having->select时
对应的表的形态。即整个查询没有select子查询作为字段时对应的输出。
1
2
3
4
5
6
7
8
9
23、按各科成绩进行排序,并显示排名

–Score重复时合并名次(利用select字段里的子查询,利用两张表的关联之后通过score的大小的个数来生成序列)
select t.* , (select count(distinct score)
from sc
where cno = t.cno
and score >= t.score) as px
from sc t
order by t.cno, px
#这里的s指的就是外表s按照sql的执行顺序,从from到where->group by->having->select时对应的表的形态(这里即
Select *
FROM sc s
ORDER BY s.cno,s.score desc
的输出结果!)
之后在select子查询中利用连表进行连接
1
2
3
4
5
6
7
8
9
10
11
12
13
24、查询学生平均成绩及其名次

SELECT a.,(SELECT count(1) FROM
(select s.
,avg(sc.score) as avg2
FROM student s
left JOIN sc on sc.sno=s.sno
WHERE avg2>=a.avg1
GROUP BY s.sno
ORDER BY avg(sc.score) desc) b
)
FROM
(select s.*,avg(sc.score) as avg1
FROM student s
left JOIN sc on sc.sno=s.sno
GROUP BY s.sno
ORDER BY avg(sc.score) desc) a
1
2
3
4
5
6
7
8
9
10
11
12
13
14

实例说明原理:

查询学生成绩及其名次

select t.*
FROM sc t
GROUP BY t.cno
ORDER BY cno,score desc
1
2
3
4
主查询的输出结果

select t.*,
(SELECT count(DISTINCT score)
FROM sc
WHERE cno=t.cno
and score>=t.score)
FROM sc t
GROUP BY t.cno
ORDER BY cno,score desc
1
2
3
4
5
6
7
8
最终输出结果
https://www.qichamao.com/person/e439e064bccf5679f408a72d659fb66c8ffdccc36b10343fe7c75daee8b53ca7-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/49e8c908e991d03a20d70419eb28d118430bf159428c745bd45e2340b5766b423da840dd9d3e630d48833c9441aaa107-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/756681c1ab74528f49b17887ace164bed8b222e9f848b506fed3b81d444799ece26d8eb2091a229c6999c0feaab40a5d-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/9187244f10411f48cc0a47de347f4cdc16c8a263b10f20ac3b9152f57814e64eb47088ebaa7a2a2ee050510e5a54b597-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/6dc05c5636ed0af35326f662871e5a8e97e37514381a528b0131563ce4cea548-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/afc76c00da1f572cfee5a321088bc178fbf1a99f1644ea232e0fb81c088c47fe-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/f1558480520bdfd53611b830b10089bea1bc19a72596609606bc92373a96631a-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/28d1eb60e71c3fe39dd20bf807c68ba788a99e3dd4b0077b9a9cc1fc8c0fa890-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/6dde693d951c305179db31ebef7b442da965b61bf4d2f739e4c2b87664d369c648a83fec1646227568a95f3d58e6d037-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/de40b407c01988f8eac454dc87da02f64284fbec0a5fa8864e46e95f2bdfa293-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/ac5721960064c73cfc808fb7503eba9fa11361da8528bff9a4cc6b48013a3aec-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/a327f25e20faeed026f4a8c3ae613e1468068041f926e5d335a67f3a8bda43d4-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/639953d295ee5b48a0654fabb784cff7424cc35d1f86a0ef6302c794c5f2330e-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/c7e79e694d47f0a1b359cc416b67b8371ea3cf3cd09035872b4924711b207bee-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/5f627e09f608924187ccb36e6bb02001b0293d8e0dafedbd5654e84cd16630a3-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/8b8327e11877d424c13024b7ab8d7fb33cf928fc7803fcc671cfe48b86e11782-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/a487fbd68b1a34ac9940103ac46019d650737853f2f0ef4b4f3401d7799120d7-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/7089dbcfc65c2b6bf91737f2974abbe8057db0c93c5f7b88eaa87e095480045c-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/a8776b2d9e6b2699990a1a4f6b25dd2a235d8f1d2faba519d6b7c156ea181dc40333c0882e83fdd055311bddd3ad92fd-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/aee1c71646cbd754696febf49c53eab2d079ec4cd2df23beda8cd0a637fbb8020d19ecc7a9b73383e596749735690d6a-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/604330f3be981120919787511affc53c7d918902592a5582c313e5a858b5a3c01f0e7c0aa4990dc57a3fbbd94b4c584e-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/bd9c8e9247a8b01f0c3db8688ac1096aefbc821f29ed5c1af2d9b2b0052565a1aa8eb0403d555d1c6ee1ffca15d141f5-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/5b4d0e8c11040e1cb1c7c95b0ac657a4864fa43cc697d98b4d41a7a59e88d56bc6a25f60654f6edf135cad4d45c2c66e-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/ff2a54d28be1116c4801a098d6044ea4c1e61abfe195716020c37d3d9bab35a1-2a6e52ffdd387b1510b9e27362ee9011
https://www.qichamao.com/person/99e5c891fbb30eb5165443ba2337809b129b3e25cfa5e21e248cb133913201db-2a6e52ffdd387b1510b9e27362ee9011
解释:这里在子查询的t就是主查询的输出结果(如上图所示),然后拿t和sc做连接查询再加上score>=t.score的限制条件,得到最终结果(即sc中对应的各科的成绩要大于t.score)

25、查询每门课程的平均成绩,结果按平均成绩降序排列,平均成绩相同时,按课程编号升序排列

#注意cast函数的应用
select cno,(CAST(avg(score) as DECIMAL(18,2))) as avg_score
FROM sc
GROUP BY cno
ORDER BY avg_score desc,cno desc
1
2
3
4
5
26、查询选修"张三"老师所授课程的学生中,成绩最高的学生信息及其成绩
https://blog.csdn.net/sturgsslecofwe/article/details/97938462
https://blog.csdn.net/sturgsslecofwe/article/details/97938714
https://blog.csdn.net/sturgsslecofwe/article/details/97938976

SELECT sno
FROM sc
WHERE cno=‘01’
ORDER BY score desc
LIMIT 1
(查询topn的另一种方法,通过orderby排序后利用limit来实现)
1
2
3
4
5
6
27、查询不同课程成绩相同的学生的学生编号、课程编号、学生成绩

#注意下几种join的链接结果
SELECT *
FROM sc a
join sc b
WHERE a.cno!=b.cno
and a.score=b.score
and a.sno!=b.sno
1
2
3
4
5
6
7
总结:
内连接是最常见的一种连接,只连接匹配的行

LEFT JOIN返回左表的全部行和右表满足ON条件的行,如果左表的行在右表中没有匹配,那么这一行右表中对应数据用NULL代替。

FULL JOIN 会从左表 和右表 那里返回所有的行。如果其中一个表的数据行在另一个表中没有匹配的行,那么对面的数据用NULL代替

其他
累加求和套路(求截止当前月份的累计消费额)
练习数据:
建表语句:

create table test
(
user VARCHAR(3),
month DATE,
salary NUMERIC(6)
);
INSERT INTO test(user, month, salary) VALUES (‘A’, ‘2015-01-03 15:20:52’, 33);
INSERT INTO test(user, month, salary) VALUES (‘A’, ‘2015-01-05 15:20:52’, 23);
INSERT INTO test(user, month, salary) VALUES (‘A’, ‘2015-01-08 15:20:52’, 66);
INSERT INTO test(user, month, salary) VALUES (‘A’, ‘2015-02-08 15:20:52’, 55);
INSERT INTO test(user, month, salary) VALUES (‘A’, ‘2015-02-02 15:20:52’, 35);
INSERT INTO test(user, month, salary) VALUES (‘B’, ‘2015-02-02 15:20:52’, 62);
INSERT INTO test(user, month, salary) VALUES (‘B’, ‘2015-02-12 15:20:52’, 52);
INSERT INTO test(user, month, salary) VALUES (‘B’, ‘2015-01-12 15:20:52’, 52);
INSERT INTO test(user, month, salary) VALUES (‘B’, ‘2015-01-16 15:20:52’, 23);
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
数据展示:

1、求每个用户每月的消费总和:

SELECT user,date_format(month, ‘%Y-%m’),sum(salary)
from test
GROUP BY user,date_format(month, ‘%Y-%m’)
1
2
3

2、将月总金额表 自己连接 自己连接

SELECT * FROM
(SELECT user,date_format(month, ‘%Y-%m’),sum(salary)
from test
GROUP BY user,date_format(month, ‘%Y-%m’)) a
join
(SELECT user,date_format(month, ‘%Y-%m’),sum(salary)
from test
GROUP BY user,date_format(month, ‘%Y-%m’)) b
on a.user=b.user
1
2
3
4
5
6
7
8
9

3、从上一步的结果中
进行分组查询,分组的字段是a.username a.month
求月累计值: 将b.month <= a.month的所有b.salary求和即可
最终求用户A和B每月累计消费总和:

SELECT a.user,a.dt,max(a.money),sum(b.money) FROM
(SELECT user,date_format(month, ‘%Y-%m’) dt,sum(salary) money
from test
GROUP BY user,date_format(month, ‘%Y-%m’)) a
join
(SELECT user,date_format(month, ‘%Y-%m’) dt,sum(salary) money
from test
GROUP BY user,date_format(month, ‘%Y-%m’)) b
on a.user=b.user
WHERE a.dt>=b.dt
GROUP BY a.user,a.dt
1
2
3
4
5
6
7
8
9
10
11


作者:春雨里de太阳
来源:CSDN
原文:https://blog.csdn.net/qq_16633405/article/details/91404823
版权声明:本文为博主原创文章,转载请附上博文链接!

这篇关于查询topn的另一种方法通过orderby排序后利用limit来实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/693271

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施: