你如何扮演一个IF ... ELSE,它会在产生相同结果的查询中产生互斥结果?
作为主体(当前登录用户),我可以获得组织中的用户列表。如果我被分配到任何部门,则用户列表是分配给相同部门的较小集合。
DECLARE @organizationId int = 421;
DECLARE @userId int = 1138;
IF EXISTS (SELECT * FROM dbo.DepartmentsUsers WHERE organizationId = @organizationId AND userId = @userId)
-- Get user IDs in the same department(s) as the principal.
SELECT du.userId
FROM dbo.DepartmentsUsers AS du
JOIN (
-- Get department IDs assigned to the principal.
SELECT departmentId
FROM dbo.DepartmentsUsers
WHERE organizationId = @organizationId
AND userId = @userId) AS j
ON du.departmentId = j.departmentId
WHERE du.organizationId = @organizationId
ELSE
-- Get all user IDs in the organization.
SELECT userId
FROM dbo.OrganizationsUsers
WHERE organizationId = @organizationId
答案 0 :(得分:1)
使用"如果"条件添加到每个where子句:
SELECT du.userId
FROM dbo.DepartmentsUsers AS du
JOIN ( SELECT departmentId
FROM dbo.DepartmentsUsers
WHERE organizationId = @organizationId
AND userId = @userId) AS j
ON du.departmentId = j.departmentId
WHERE du.organizationId = @organizationId
AND EXISTS (SELECT * FROM dbo.DepartmentsUsers WHERE organizationId = @organizationId AND userId = @userId)
UNION
SELECT userId
FROM dbo.OrganizationsUsers
WHERE organizationId = @organizationId
AND NOT EXISTS (SELECT * FROM dbo.DepartmentsUsers WHERE organizationId = @organizationId AND userId = @userId)
答案 1 :(得分:0)
SELECT du.userId as UserId,
'Department' as UserType // remove this line unnecessary
FROM dbo.DepartmentsUsers AS du
JOIN (
-- Get department IDs assigned to the principal.
SELECT departmentId
FROM dbo.DepartmentsUsers
WHERE organizationId = @organizationId
AND userId = @userId) AS j
ON du.departmentId = j.departmentId
WHERE du.organizationId = @organizationId
UNION ALL
-- Get all user IDs in the organization.
SELECT userId as UserId,
'Organization' as UserType // remove this line unnecessary
FROM dbo.OrganizationsUsers
WHERE organizationId = @organizationId