微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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)

原文地址:https://www.jb51.cc/mssql/81556.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐