SELECT语句的SQL别名

我想做一些类似的事情
(SELECT ... FROM ...) AS my_select
WHERE id IN (SELECT MAX(id) FROM my_select GROUP BY name)

是否可能以某种方式执行“AS my_select”部分(即为SELECT语句分配别名)?

(注意:这是一个理论问题,我意识到我可以在没有为SELECT语句分配别名的情况下执行,但我想知道是否可以这样做)

解决方法

不太确定你用这种语法来表示什么,但是在几乎所有的RDBMS-es中,你可以使用FROM子句中的子查询(有时称为“inline-view”):
SELECT..
FROM (
     SELECT ...
     FROM ...
     ) my_select
WHERE ...

在高级“企业”RDBMS-es(如oracle,sql Server,postgresql)中,您可以使用通用表表达式,允许您通过名称引用查询,甚至多次重用它:

-- Define the CTE expression name and column list.
WITH Sales_CTE (SalesPersonID,SalesOrderID,SalesYear)
AS
-- Define the CTE query.
(
    SELECT SalesPersonID,YEAR(OrderDate) AS SalesYear
    FROM Sales.SalesOrderHeader
    WHERE SalesPersonID IS NOT NULL
)
-- Define the outer query referencing the CTE name.
SELECT SalesPersonID,COUNT(SalesOrderID) AS TotalSales,SalesYear
FROM Sales_CTE
GROUP BY SalesYear,SalesPersonID
ORDER BY SalesPersonID,SalesYear;

(例如http://msdn.microsoft.com/en-us/library/ms190766(v=sql.105).aspx)

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...