mysql中grade字段降序排列_MySQL_SQL实际操作练习题答案

1:查询雇员表中工资最高的雇员的员工号、员工姓名、工资和部门号。

select empno,ename,sal,deptno from emp

where sal = (select max(sal) from emp);

2:薪水大于1200的雇员,按照部门编号进行分组,分组后的平均薪水必须大于1500,查询各分组的平均工资,按照工资的倒序进行排列。

select avg(sal) avg_sal, deptno

from emp

where sal > 1200

group by deptno

having avg_sal > 1500

order by avg_sal desc;

说明:此句基本上包含了SQL语句的子语句和排列顺序:select(要查询的字段)->from(从哪一张或哪几张表或视图)->where(过滤条件)->group by(having)(分组及条件)->order by(按哪个或哪几个字段进行升序或降序排列)。

注意:SqlServer4.1中可能不支持在order语句中使用组函数avg,报错说:invalid use of group f unction(错误提示和现象有点对不上)

解决办法:给avg(sal)起个别名avg_sal,这样在order语句中就直接使用这个别名

3:等值连接:

查询每个雇员和其所在的部门名

select ename,dname from emp,dept where (emp.deptno = dept.deptno);

或者(推荐)(on中就写连接条件,where中就写过滤条件,各司其职)

select ename,dname from emp join dept on(emp.deptno = dept.deptno);

4:非等值连接:

查询每个雇员姓名及其工资所在的等级

select ename,grade from emp e join salgrade s on(e.sal between s.losal and s.hisal); 5:查询雇员名第2个字母不是a的雇员的姓名、所在的组名、工资所在的等级。

三张表的连接查询(先连接,再加上where语句进行过滤)

select ename,dname,grade

from emp e join dept d on(e.deptno = d.deptno)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值