SELECT语句的SQL别名

前端之家收集整理的这篇文章主要介绍了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)

猜你在找的MsSQL相关文章