使用 SQL Server 将子查询结果重用于其他计算

Posted

技术标签:

【中文标题】使用 SQL Server 将子查询结果重用于其他计算【英文标题】:Reuse subquery results for other computations with SQL Server 【发布时间】:2013-07-15 18:30:49 【问题描述】:

我在 Access 中有一组类似这样的查询运行良好,但是当我尝试在 MS SQL 中将它们设为视图或存储过程时,它告诉我子查询的别名不是稍后使用的有效列在查询中运行计算。

这是我在 Access 中的内容:

SELECT T.DistrictNum,

(select count(winner) from TournyGames2013 where type='Pool 1' and winner=T.DistrictNum) AS TeamWins, 
(select count(loser) from TournyGames2013 where type='Pool 1' and loser=T.DistrictNum) AS TeamLoses,
([TeamWins]+[TeamLoses]) AS GameTotal
FROM TournyTeams2013 AS T
WHERE T.Pool=1

我究竟如何从中创建一个有效的视图或存储过程? 谢谢,温柔点,我在这里的第一篇文章。

【问题讨论】:

【参考方案1】:

在 SQL Server 中(与其他遵循 ANSI 标准的数据库一样),您不能引用与定义它的 select 相同级别的别名。

您可以使用子查询轻松解决此问题:

select t.*, ([TeamWins]+[TeamLoses]) AS GameTotal
from (SELECT T.DistrictNum,
             (select count(winner) from TournyGames2013 where type='Pool 1' and winner=T.DistrictNum) AS TeamWins, 
             (select count(loser) from TournyGames2013 where type='Pool 1' and loser=T.DistrictNum) AS TeamLoses
      FROM TournyTeams2013 AS T
      WHERE T.Pool=1
     ) t

【讨论】:

以上是关于使用 SQL Server 将子查询结果重用于其他计算的主要内容,如果未能解决你的问题,请参考以下文章

sqlserver分页去重失效

SQL Server PRINT SELECT(打印选择查询结果)?

Python-Sqlalchemy-Postgres:如何将子查询结果存储在变量中并将其用于主查询

在 SQL Server 中合并查询中的行

尝试将子表单记录源设置为 sql 查询时出错

使用 SQL Server 将逗号分隔的文本转换为多列结果