免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3686 | 回复: 8
打印 上一主题 下一主题

[数据库] oracle查询语句不对,求老鸟指点。。。 [复制链接]

论坛徽章:
1
天蝎座
日期:2014-10-18 18:48:57
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-12-15 21:50 |只看该作者 |倒序浏览
大牛,帮忙看看这个查询语句为什么不对。。。表示hr用户下的表。。查询工资小于部门平均工资的员工。

求老鸟指点,最好能说明一下,具体原因。。
  select last_name, salary, e.department_id
          from employees e
          join (select department_id, avg(salary) "avgl" from employees group by department_id) s
          on e.department_id=s.department_id
          having e.salary<=s.avgl


ERROR at line 5:
ORA-00904: "S"."AVGL": invalid identifier

论坛徽章:
7
亥猪
日期:2013-10-10 17:00:29辰龙
日期:2013-10-12 16:23:19卯兔
日期:2013-11-18 17:01:27金牛座
日期:2014-09-09 10:17:052015七夕节徽章
日期:2015-08-21 11:06:172015亚冠之柏太阳神
日期:2015-09-25 13:56:42数据库技术版块每日发帖之星
日期:2016-08-06 06:20:00
2 [报告]
发表于 2014-12-16 16:31 |只看该作者
请使用and;而非having

论坛徽章:
1
天蝎座
日期:2014-10-18 18:48:57
3 [报告]
发表于 2014-12-16 22:22 |只看该作者
为什么不能使用having啊。。。。回复 2# li0924


   

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2016-04-28 14:27:11
4 [报告]
发表于 2014-12-18 10:31 |只看该作者
换成 and 或 where 都可以,不能使用 having ,having 是要配合 group by 使用的,但是你这个子查询中的 group by 不算。

另外,建议你把  avg(salary) "avgl" 中的引号去掉,没什么用。

论坛徽章:
1
天蝎座
日期:2014-10-18 18:48:57
5 [报告]
发表于 2014-12-19 10:10 |只看该作者
我明白了,哎呀,一时脑袋发热没想清楚。。。。哈哈。。。having是不能这么用。。谢谢。。。回复 4# wmxcn2000


   

论坛徽章:
1
天蝎座
日期:2014-10-18 18:48:57
6 [报告]
发表于 2014-12-19 10:22 |只看该作者
老鸟,请问,为什么我在句子中使用“”  双引号命名别人在这里就不对了呢。。提示:

  1    select last_name, salary, e.department_id
  2    from employees e
  3    join (select department_id, avg(salary) "avgl" from employees group by department_id) s
  4*   on e.department_id=s.department_id and e.salary<=s.avgl
hr@ORCL> /
  on e.department_id=s.department_id and e.salary<=s.avgl
                                                   *
ERROR at line 4:
ORA-00904: "S"."AVGL": invalid identifier
wmxcn2000 发表于 2014-12-18 10:31
换成 and 或 where 都可以,不能使用 having ,having 是要配合 group by 使用的,但是你这个子查询中的 gr ...

论坛徽章:
1
天蝎座
日期:2014-10-18 18:48:57
7 [报告]
发表于 2014-12-19 10:51 |只看该作者
老鸟,如果我在别名中使用的是 中间有空格的 "s avgl" 改怎么写呢??

  select last_name, salary, e.department_id
          from employees e
          join (select department_id, avg(salary) "s avgl" from employees group by department_id) s
          on e.department_id=s.department_id and having e.salary<=s. 's avgl' --这里是错的,请问该怎么写?
wmxcn2000 发表于 2014-12-18 10:31
换成 and 或 where 都可以,不能使用 having ,having 是要配合 group by 使用的,但是你这个子查询中的 gr ...

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2016-04-28 14:27:11
8 [报告]
发表于 2014-12-19 13:52 |只看该作者
回复 6# 蓦然princes


    如果你使用了双引号做为列的别名,在你引用这列时,也要加双引号, 或者你起别名的时, 使用大写字母。

论坛徽章:
1
天蝎座
日期:2014-10-18 18:48:57
9 [报告]
发表于 2014-12-19 14:27 |只看该作者
太棒了,你好厉害啊,我以前没有遇到过使用别名,这次突然遇到,语法不对不知道了。。。。哈哈。。。。谢谢啊。。。。回复 8# wmxcn2000


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP