关于在oracle字段使用别名所出现的 标识符无效的情况

本文探讨了SQL查询中的别名使用规则,强调了在`WHERE`子句中不能直接使用别名,而`ORDER BY`可以。解释了SQL执行顺序:`WHERE` -> `GROUP BY` (如果存在) -> 别名与函数计算 -> `ORDER BY`。内容对于理解SQL查询优化和正确使用字段别名具有指导意义。
摘要由CSDN通过智能技术生成
SELECT
	a.ID AS "id",
	a.SENSOR_ID AS "sensorId",
	a.START_TIME AS "startTime",
	a.END_TIME AS "endTime",
	a.STATUS AS "status" 
FROM
	SENSOR_STATUS a 
WHERE
	1 = 1 
ORDER BY
	endTime

结果:
在这里插入图片描述
然后查询了关于oracle的别名的使用注意事项:

where子句中只能直接使用栏位或者常量,而不能使用栏位的别名,除非这个别名来自子查询之中

而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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值