sql-server – 如何正确嵌套CTE

栏目: 数据库 · 发布时间: 7年前

内容简介:很少有人问过这个问题,但我仍然无法找到正确的答案或正确的方法来做到这一点:…这不起作用,我无法创建存储过程,显然我不能在WHERE中使用Loss,因为在该范围内不存在.

很少有人问过这个问题,但我仍然无法找到正确的答案或正确的方法来做到这一点:

;WITH CTE AS
(
  SELECT * FROM ...
)
SELECT *, [dbo].[udf_BetaInv](A, B, C, D) AS 'Loss'
FROM CTE
WHERE (Loss >= @MinRetention)

这不起作用,我无法创建存储过程,显然我不能在WHERE中使用Loss,因为在该范围内不存在.

我想用另一个CTE来包装这个,所以我可以把WHERE放在外面的那个但是似乎不起作用,试过这个:

;WITH CTE AS
(
  SELECT * FROM ...
)
SELECT *, [dbo].[udf_BetaInv(A, B, C, D) AS 'Loss'
FROM CTE,
RESULTS AS
(SELECT * FROM CTE)
  SELECT *
  FROM RESULTS
  WHERE (Loss >= @MinRetention)

但它没有在SQL Server中编译,我得到一个错误,”’错误地放在上面的许多行但没有任何关系,如果我删除第二个CTE它工作正常.

我只想避免代码重复,不想在select和in中调用我的[udf_BetaInv]两次.


以上所述就是小编给大家介绍的《sql-server – 如何正确嵌套CTE》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Out of their Minds

Out of their Minds

Dennis Shasha、Cathy Lazere / Springer / 1998-07-02 / USD 16.00

This best-selling book is now available in an inexpensive softcover format. Imagine living during the Renaissance and being able to interview that eras greatest scientists about their inspirations, di......一起来看看 《Out of their Minds》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

SHA 加密
SHA 加密

SHA 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具