我心流浪 2012-08-13 17:36
浏览 456
已采纳

Oracle别名使用问题

表结构与表数据:
create table fruit(fruitname varchar2(20),product varchar2(20),price varchar2(20));
insert into fruit values('apple','china','12');
insert into fruit values('apple','japan','22');
insert into fruit values('apple','usa','33');
insert into fruit values('orange','china','10');
insert into fruit values('banana','china','31');
insert into fruit values('peach','usa','30');

问题:
1> select fruitname f from fruit where f='apple'; //无效的标识符
2> select fruitname f from fruit where fruitname='apple'; //正确
3> select fruitname,count(*) c from fruit group by fruitname having c>0; //无效的标识符
4> select fruitname,count(*) c from fruit group by fruitname having count(*)>0; //正确
5> select fruitname,count(*) c from fruit group by fruitname having count(*)>0 order by c; //正确


上述五个问题的运行结果为什么是那样,请解释下?

在from子句中为表指定了别名,表的实际名称是不是被覆盖了?

  • 写回答

2条回答 默认 最新

  • liuyinhuan0409 2012-08-14 10:41
    关注

    Oracle中的sql语句,
    1.where/group by/having子句中只能直接使用栏位或者常量,而不能使用栏位的别名,除非这个别名来自子查询之中,如:select .... from (select col1 ccc from table) where ccc > 1
    2.而order by 则可以直接使用别名,如select col1 ccc from table order by ccc

    这和sql 的执行顺序是有关的,where中的部分先执行 -> 如果有group by,接着执行group by -> select中的函数计算、别名指定再运行-> 最后order by
    因此,字段、表达式的别名在where子句和group by子句都是不能使用的,而在order by中不仅可以使用别名,甚至可以直接使用栏位的下标来进行排序,如:order by 1 desc,2 asc

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 vue3加ant-design-vue无法渲染出页面
  • ¥15 matlab(相关搜索:紧聚焦)
  • ¥15 基于51单片机的厨房煤气泄露检测报警系统设计
  • ¥15 路易威登官网 里边的参数逆向
  • ¥15 Arduino无法同时连接多个hx711模块,如何解决?
  • ¥50 需求一个up主付费课程
  • ¥20 模型在y分布之外的数据上预测能力不好如何解决
  • ¥15 processing提取音乐节奏
  • ¥15 gg加速器加速游戏时,提示不是x86架构
  • ¥15 python按要求编写程序