码迷,mamicode.com
首页 > 数据库 > 详细

关于分组的sql语句

时间:2015-06-29 16:25:17      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:

原文   http://www.cnblogs.com/tianxue/p/4493260.html

这确实是一个真实的面试题,琢磨一下吧!知识不用,就会丢掉,我太依赖各种框架和dll了,已经忘记了最基本的东西。有多久没有写过SQL了,我已经不记得了。

已知表信息如下:

Department(depID, depName),depID 系编号,DepName系名

Student(stuID, name, depID) 学生编号,姓名,系编号

Score(stuID, category, score) 学生编码,科目,成绩

找出每一个系的最高分,并且按系编号,学生编号升序排列,要求顺序输出以下信息:

系编号,系名,学生编号,姓名,总分

数据:

技术分享
USE [test]
GO
/****** Object:  Table [dbo].[Score]    Script Date: 05/11/2015 23:16:23 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_PADDING ON
GO
CREATE TABLE [dbo].[Score](
    [stuID] [int] NOT NULL,
    [category] [varchar](50) NOT NULL,
    [score] [int] NOT NULL
) ON [PRIMARY]
GO
SET ANSI_PADDING OFF
GO
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (1, N英语, 80)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (2, N数学, 80)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (1, N数学, 70)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (2, N英语, 89)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (3, N英语, 81)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (3, N数学, 71)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (4, N数学, 91)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (4, N英语, 61)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (5, N英语, 91)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (6, N英语, 89)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (7, N英语, 77)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (8, N英语, 97)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (9, N英语, 57)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (5, N数学, 87)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (6, N数学, 89)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (7, N数学, 80)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (8, N数学, 81)
INSERT [dbo].[Score] ([stuID], [category], [score]) VALUES (9, N数学, 84)
/****** Object:  Table [dbo].[Department]    Script Date: 05/11/2015 23:16:23 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_PADDING ON
GO
CREATE TABLE [dbo].[Department](
    [depID] [int] IDENTITY(1,1) NOT NULL,
    [depName] [varchar](50) NOT NULL,
PRIMARY KEY CLUSTERED 
(
    [depID] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
SET ANSI_PADDING OFF
GO
SET IDENTITY_INSERT [dbo].[Department] ON
INSERT [dbo].[Department] ([depID], [depName]) VALUES (1, N计算机)
INSERT [dbo].[Department] ([depID], [depName]) VALUES (2, N生物)
INSERT [dbo].[Department] ([depID], [depName]) VALUES (3, N数学)
SET IDENTITY_INSERT [dbo].[Department] OFF
/****** Object:  Table [dbo].[Student]    Script Date: 05/11/2015 23:16:23 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_PADDING ON
GO
CREATE TABLE [dbo].[Student](
    [stuID] [int] IDENTITY(1,1) NOT NULL,
    [stuName] [varchar](50) NOT NULL,
    [deptID] [int] NOT NULL,
PRIMARY KEY CLUSTERED 
(
    [stuID] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
SET ANSI_PADDING OFF
GO
SET IDENTITY_INSERT [dbo].[Student] ON
INSERT [dbo].[Student] ([stuID], [stuName], [deptID]) VALUES (1, N计算机张三, 1)
INSERT [dbo].[Student] ([stuID], [stuName], [deptID]) VALUES (2, N计算机李四, 1)
INSERT [dbo].[Student] ([stuID], [stuName], [deptID]) VALUES (3, N计算机王五, 1)
INSERT [dbo].[Student] ([stuID], [stuName], [deptID]) VALUES (4, N生物amy, 2)
INSERT [dbo].[Student] ([stuID], [stuName], [deptID]) VALUES (5, N生物kity, 2)
INSERT [dbo].[Student] ([stuID], [stuName], [deptID]) VALUES (6, N生物lucky, 2)
INSERT [dbo].[Student] ([stuID], [stuName], [deptID]) VALUES (7, N数学_yiming, 3)
INSERT [dbo].[Student] ([stuID], [stuName], [deptID]) VALUES (8, N数学_haoxue, 3)
INSERT [dbo].[Student] ([stuID], [stuName], [deptID]) VALUES (9, N数学_wuyong, 3)
SET IDENTITY_INSERT [dbo].[Student] OFF
/****** Object:  Default [DF__Departmen__depNa__5441852A]    Script Date: 05/11/2015 23:16:23 ******/
ALTER TABLE [dbo].[Department] ADD  DEFAULT (‘‘) FOR [depName]
GO
/****** Object:  Default [DF__Score__category__5EBF139D]    Script Date: 05/11/2015 23:16:23 ******/
ALTER TABLE [dbo].[Score] ADD  DEFAULT (‘‘) FOR [category]
GO
/****** Object:  Default [DF__Score__score__5FB337D6]    Script Date: 05/11/2015 23:16:23 ******/
ALTER TABLE [dbo].[Score] ADD  DEFAULT ((0)) FOR [score]
GO
/****** Object:  Default [DF__Student__stuName__59063A47]    Script Date: 05/11/2015 23:16:23 ******/
ALTER TABLE [dbo].[Student] ADD  DEFAULT (‘‘) FOR [stuName]
GO
/****** Object:  ForeignKey [FK__Student__deptID__59FA5E80]    Script Date: 05/11/2015 23:16:23 ******/
ALTER TABLE [dbo].[Student]  WITH CHECK ADD FOREIGN KEY([deptID])
REFERENCES [dbo].[Department] ([depID])
GO

准备环境
View Code

--------------使用group by 

--总分
with studentTotalScore as
(
select st.deptid,de.depname, st.stuid ,st.stuname,sum(score) as totalScore from student as st
join score as sc on st.stuid=sc.stuid
join department as de on de.depid=st.deptid
group by st.deptid,de.depname, st.stuid,st.stuname
)
--系最高分
, depMaxScore as
(
select de.depid,max(sts.totalscore) as maxScore from department as de
join student as stu on stu.deptid=de.depid
join studentTotalScore as sts on stu.stuid=sts.stuid
group by de.depid
)
--总分和最高分合并
select sts.depname,sts.deptid,sts.stuname,sts.stuid,dems.maxScore from studentTotalScore sts
join depmaxscore dems on sts.deptid=dems.depid and sts.totalScore=dems.maxscore

 

----------使用partion 
--总分
with studentTotalScore as
(
select distinct st.deptid,de.depname, st.stuid ,st.stuname,
sum(score) over(partition by st.stuid) as totalScore from student as st
join score as sc on st.stuid=sc.stuid
join department as de on de.depid=st.deptid
)
--系最高分
, depMaxScore as
(
select distinct de.depid,max(sts.totalscore) over (partition by de.depid) as maxScore from department as de
join student as stu on stu.deptid=de.depid
join studentTotalScore as sts on stu.stuid=sts.stuid
)
--总分和最高分合并
select sts.depname,sts.deptid,sts.stuname,sts.stuid,dems.maxScore from studentTotalScore sts
join depmaxscore dems on sts.deptid=dems.depid and sts.totalScore=dems.maxscore

 

结果:

计算机 1 计算机李四 2 169
生物 2 生物kity 5 178
生物 2 生物lucky 6 178
数学 3 数学_haoxue 8 178

关于分组的sql语句

标签:

原文地址:http://www.cnblogs.com/wuMing-dj/p/4607543.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!