我想做一些类似的事情
(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)