我想运行一个SQL查询(SQL Server),它将从子查询中查找一个名称列表。从一个表中选择值,其中=另一个值?
我有这个,但我得到一个“子查询返回多于1”的错误:
SELECT FirstName + ' ' + LastName AS Name
FROM Members
WHERE
(MemberGUID = (SELECT ClassDetails.Leader
FROM Members AS Members_1
INNER JOIN MemberDetails ON Members_1.MemberGUID = MemberDetails.Member
INNER JOIN ClassDetails ON ClassDetails.Class = Members_1.CurrentClass
WHERE
(MemberDetails.JoiningDate >= '02/03/2012')
AND (Members_1.FirstName = '*')
OR (MemberDetails.JoiningDate >= '02/03/2012')
AND (Members_1.LastName = '*')
OR (MemberDetails.JoiningDate >= '02/03/2012')
AND (MemberDetails.Email IS NULL)
AND (MemberDetails.MobilePhone IS NULL)
AND (MemberDetails.WorkPhone IS NULL)
AND (MemberDetails.HomePhone IS NULL)
AND (Members_1.CurrentClass <> 339)
AND (Members_1.CurrentClass <> 696)
AND (Members_1.CurrentClass <> 0)))
我需要这个返回值FirstName
和LastName
在子查询返回的每一个值。 (该子查询返回应该被输入到WHERE MemberGUID
声明中的GUID列表)
这怎么办?
点到你,因为你最后一刻落败Guffa几秒;) 非常感谢完美! - 是否可以列出名称旁边的出现次数?即'Myles Gray | 5',因为一些GUID出现几次,这个数字很重要? – 2012-02-12 16:07:26
这是可能的,但不是没有你的一部分重构。简而言之,我认为最简单的做法是创建一个CTE或一个保存GUID和它们的计数的临时表。 (类似于'SELECT Id,Count(Id)FROM ... WHERE ... GROUP By Id')然后加入'Member',从'Member'和从CTE/Temp表中选择名字。 – 2012-02-12 16:21:26
@MylesGray:你应该选择最好的答案,不一定是第一个答案。此外,如果你检查时间,我的回答是第一个... – Guffa 2012-02-12 16:39:22