在查询中返回多个值的子查询
我正在尝试创建一个视图,该视图包含执行计算以确定要生成哪个字段的部分。但是,我遇到了子查询的问题。在查询中返回多个值的子查询
每当我试图执行的观点,我收到错误消息:Subquery returned more than 1 value. This is not permitted when the subquery follows =, !=, <, <= , >, >= or when the subquery is used as an expression.
我明白了什么是说明,通常我会用WHERE
子句和子查询中的参数解决这个问题。但是,由于我需要将此视为一种观点,因此我如何缓解此问题?我已经为多个案例独立运行子查询,并验证他们确实每个订单返回一行。是否有可能让子查询仅从当前行中的单个结果中选择它在视图中?
这是视图的特定部分的代码片段。任何建议,你们可以提供将不胜感激。
SELECT
CASE
WHEN ORC.SimultaneousCalculation = 1
THEN CASE
WHEN -- Select the Owner's Simultaneous Report Code when Sales Price >= Loan Amount.
(SELECT
CASE
WHEN (ISNULL(O.OwnerPolicyLiability, 0) = 0)
THEN O.SalesPrice
WHEN (ISNULL(O.OwnerPolicyLiability, 0) > 0)
THEN (O.OwnerPolicyLiability)
ELSE 0 END AS 'SalesPrice'
FROM
Orders O) >=
(SELECT
CASE
WHEN (ISNULL(L.LoanPolicyLiability, 0) = 0)
THEN L.Amount
WHEN (ISNULL(L.LoanPolicyLiability, 0) > 0)
THEN (L.Amount)
ELSE 0 END AS 'LoanAmount'
FROM
Orders O
INNER JOIN Loan L
ON O.OrdersID = L.OrdersID
AND L.LoanOrder = 1)
THEN CONVERT(VARCHAR(MAX),RES.SalesPolicyCode)
WHEN -- Select the Owner's Simultaneous Report Code when Sales Price < Loan Amount.
(SELECT
CASE
WHEN (ISNULL(O.OwnerPolicyLiability, 0) = 0)
THEN O.SalesPrice
WHEN (ISNULL(O.OwnerPolicyLiability, 0) > 0)
THEN (O.OwnerPolicyLiability)
ELSE 0 END AS 'SalesPrice'
FROM
Orders O) <
(SELECT
CASE
WHEN (ISNULL(L.LoanPolicyLiability, 0) = 0)
THEN L.Amount
WHEN (ISNULL(L.LoanPolicyLiability, 0) > 0)
THEN (L.Amount)
ELSE 0 END AS 'LoanAmount'
FROM
Orders O
INNER JOIN Loan L
ON O.OrdersID = L.OrdersID
AND L.LoanOrder = 1)
THEN CONVERT(VARCHAR(MAX),RES.LoanPolicyCode)
ELSE CONVERT(VARCHAR(MAX),0) END
-- If not Simultaneous, select the primary rate's Report Code.
ELSE CONVERT(VARCHAR(MAX),R.ReportCode)
END AS 'PremCode'
,O.Col1
,O.Col2
,O.Col3
FROM
Orders O
INNER JOIN OrderRateCalculation ORC
ON O.OrdersID = ORC.OrdersID
LEFT JOIN Rate R
ON ORC.RateID = R.RateID
LEFT JOIN RateEffectiveDate RED
ON R.RateID = RED.RateID
LEFT JOIN RateEngineSimultaneous RES
ON RED.RateEffectiveDateID = RES.RateEffectiveDateID
WHERE
(ORC.LoanHolder = 1)
这是困难的没有你的表的更多的知识来回答关系,但如果是我,我会尝试找到一种方法来移动连接到‘贷款’到主加入列表,并删除子选集。类似这样的:
SELECT
CASE
WHEN ORC.SimultaneousCalculation = 1
THEN CASE
WHEN -- Select the Owner's Simultaneous Report Code when Sales Price >= Loan Amount.
CASE
WHEN (ISNULL(O.OwnerPolicyLiability, 0) = 0)
THEN O.SalesPrice
WHEN (ISNULL(O.OwnerPolicyLiability, 0) > 0)
THEN (O.OwnerPolicyLiability)
ELSE 0 END AS 'SalesPrice'
>=
CASE
WHEN (ISNULL(L.LoanPolicyLiability, 0) = 0)
THEN L.Amount
WHEN (ISNULL(L.LoanPolicyLiability, 0) > 0)
THEN (L.Amount)
ELSE 0 END AS 'LoanAmount'
THEN CONVERT(VARCHAR(MAX),RES.SalesPolicyCode)
WHEN -- Select the Owner's Simultaneous Report Code when Sales Price < Loan Amount.
CASE
WHEN (ISNULL(O.OwnerPolicyLiability, 0) = 0)
THEN O.SalesPrice
WHEN (ISNULL(O.OwnerPolicyLiability, 0) > 0)
THEN (O.OwnerPolicyLiability)
ELSE 0 END AS 'SalesPrice'
<
CASE
WHEN (ISNULL(L.LoanPolicyLiability, 0) = 0)
THEN L.Amount
WHEN (ISNULL(L.LoanPolicyLiability, 0) > 0)
THEN (L.Amount)
ELSE 0 END AS 'LoanAmount'
THEN CONVERT(VARCHAR(MAX),RES.LoanPolicyCode)
ELSE CONVERT(VARCHAR(MAX),0) END
-- If not Simultaneous, select the primary rate's Report Code.
ELSE CONVERT(VARCHAR(MAX),R.ReportCode)
END AS 'PremCode'
,O.Col1
,O.Col2
,O.Col3
FROM
Orders O
INNER JOIN OrderRateCalculation ORC
ON O.OrdersID = ORC.OrdersID
LEFT JOIN Rate R
ON ORC.RateID = R.RateID
LEFT JOIN RateEffectiveDate RED
ON R.RateID = RED.RateID
LEFT JOIN RateEngineSimultaneous RES
ON RED.RateEffectiveDateID = RES.RateEffectiveDateID
LEFT JOIN Loan L
ON O.OrdersID = L.OrdersID
AND L.LoanOrder = 1
WHERE
(ORC.LoanHolder = 1)
祝你好运!
宾果!我不知道为什么这不会跨越我的脑海。我认为我错误地认为我无法比较两个CASE语句,但这只是一个简单的失误。谢谢你,先生! – PicoDeGallo 2014-10-01 21:20:54
不客气! :) – 2014-10-01 21:22:39
这只是视图的一部分?为什么有这么多嵌套的case表达式?这确实使得难以遵循。我怀疑大部分问题是因为你的子查询不相关。他们应该有一个where子句来限制结果与外部查询相关。 – 2014-10-01 20:33:02
问题是,你的一些subquerys返回更多的一行,所以SQL服务器不知道与哪个行进行比较。您可以使用MAX或MIN来将子查询过滤为一行。 – ericpap 2014-10-01 20:34:38