互斥查询

时间:2017-09-15 22:27:58

标签: sql-server tsql

问题

你如何扮演一个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

2 个答案:

答案 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