在 Select 语句计算中使用列别名 Oracle SQL

Bra*_*sel 3 sql oracle alias oracle11g

是否可以做类似的事情select 1 as foo, foo+1 from dual

这返回ERROR at line 1: ORA-00904: "FOO": invalid identifier

我有一个组成列的冗长计算,我希望能够轻松地使用该值在差异列中进行计算

Lam*_*mak 5

您不能直接使用别名。一种方法是使用派生表:

SELECT foo, foo+1
FROM (SELECT 1 AS foo FROM dual) AS T
Run Code Online (Sandbox Code Playgroud)