请用一条sql语句求出各部门总和,最高工资者的姓名

员工表Employee字段:empId员工id,empname员工姓名,dept部门id工资表Wage字段:empId员工id,wage工资我的答案:selectname... 员工表Employee 字段:empId 员工id,empname员工姓名,dept部门id
工资表Wage 字段:empId 员工id,wage 工资
我的答案:
select name , sumWage from (
select SUM(wage) sumWage,dept from Employee e,Wage w
where e.empId = w.empId
group by dept) a,
(select max(e.empname) name ,dept from Employee e,Wage w
where e.empId = w.empId
and wage in (
select MAX(wage) maxWage from Employee e,Wage w
where e.empId = w.empId
group by e.dept)
group by dept
) b where a.dept = b.dept

求简洁的。
展开
 我来答
xckouy
2011-12-28 · TA获得超过1538个赞
知道小有建树答主
回答量:1291
采纳率:0%
帮助的人:864万
展开全部
开窗函数可以实现,我试着写了一个(好长时间没用了,估计会有点错误,你试试,有问题的话交流一下)
SELECT
max(t.empname) name,
max(wage) maxWage,
max(sumWage) sumWage,
t.dept
FROM
(
SELECT
e.empname,
w.wage,
e.dept,
sum(wage) over(partition by e.dept) sumWage
FROM
Employee e,
Wage w
WHERE
e.empId = w.empId
)
t
GROUP BY
t.dept
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wjl890719
2011-12-28 · 超过14用户采纳过TA的回答
知道答主
回答量:42
采纳率:0%
帮助的人:27.8万
展开全部
select e.empname from Employee e where e.empId in (select A.ewpId from (select Max(w.wage) , w.ewpId from Wage w) as A )
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名_热心网友
2012-01-09 · TA获得超过719个赞
知道大有可为答主
回答量:3827
采纳率:0%
帮助的人:8429万
展开全部
ORA-03113 end-of-file on communication channel

Cause: An unexpected end-of-file was processed on the communication
channel. The problem could not be handled by the Net8 two-task software. This
message could occur if the shadow two-task process associated with a Net8
connect has terminated abnormally, or if there is a physical failure of the
interprocess communication vehicle, that is, the network or server machine
went down.
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式