2

过去几天我在 Google 和 SO 上花了很多时间,但我似乎找不到我的问题的答案。不确切知道如何将问题表述为一个合理的问题会使其变得更加困难。你不知道你不知道什么,对吧?

由于业务限制,我无法发布我的确切代码和数据库结构,所以我会尽力给出一个可靠的例子。

客户表- 保存客户数据

[CustId] | [CustName]  
---------------------
1        | John Smith  
2        | Jane Doe
3        | John Doe

代码表- 保存代码数据

[CodeId] | [CodeDesc]
---------------------
A        | A Desc
B        | B Desc
C        | C Desc
D        | D Desc
E        | E Desc

CustomerCode 表- 将客户与代码组合在一起

[CustId] | [CodeId]
-------------------
1        | A
1        | B
2        | B
2        | C
2        | D
3        | C
3        | E

CodeHierarchy 表- 如果客户有 ConditionCode,则不应包含的代码层次结构 (DropCode)

[ConditionCode] | [DropCode]
----------------------------
A               | B
B               | C
B               | D

现在我将尝试解释我的实际问题。

我想要完成的是编写一个查询(视图),它将根据 CodeHierarchy 表列出代码。

结果将是这样的:

[CustName] | [CodeId]
-------------------
John Smith | A
Jane Doe   | B
John Doe   | C
John Doe   | E

没有为 John Smith 列出代码 B,因为他有代码 A。没有为 Jane Doe 列出代码 C 和 D,因为她也有代码 B。John Doe 列出了所有代码(请注意,E 甚至不在 CodeHierarchy 中桌子)。

我尝试了一些不同的东西(内部连接、左/右连接、子查询等),但我无法得到我正在寻找的结果。

作为基本查询,这将返回所有代码:

SELECT 
    Customer.CustomerName, 
    Code.CodeDesc  
FROM 
    Customer 
        INNER JOIN CustomerCode
            ON Customer.CodeId = CustomerCode.CodeId
        INNER JOIN Code
            ON CustomerCode.CodeId = Code.CodeId

这只返回 ConditionCodes 的代码(我明白为什么,但我认为当时可能值得一试):

SELECT 
    Customer.CustomerName, 
    Code.CodeDesc  
FROM 
    Customer 
        INNER JOIN CustomerCode
            ON Customer.CodeId = CustomerCode.CodeId
        INNER JOIN Code
            ON CustomerCode.CodeId = Code.CodeId
        INNER JOIN CodeHierarchy
            ON Customer.CodeId = CodeHierarchy.ConditionCode
            AND Customer.CodeId != CodeHierarchy.DropCode  

我尝试了一个子查询(没有可用的代码),无论成员是否有合格的层次结构,最终都会删除所有 DropCodes(即,即使没有 A,也不会返回带有 B 的客户行)

我有一个想法,将基本查询置于子查询之上,并将其与 CodeHierarchy 表连接起来,但我一直坚持如何编写查询:

SELECT
    *
FROM
    (
        base query (with all codes)
    ) CustomerCodesAll
        INNER/LEFT JOIN CodeHierarchy
            ON ?

我也一直在阅读 CTE,但我不确定如何使用该技术。

这最终将成为为了报告目的而被查询的视图。客户表包含更多数据,包括出生日期、性别、公司状态等。视图将很简单,可以提取所有内容。针对视图的查询将包括 dob、gender 等的 where 子句。

谁能指出我正确的方向?

谢谢你的帮助。

4

1 回答 1

3
SELECT 
    Customer.CustName, 
    Code.CodeDesc
FROM 
    Customer 
        INNER JOIN CustomerCode AS posCustomerCode
            ON Customer.CustId = posCustomerCode.CustId
        INNER JOIN Code
            ON posCustomerCode.CodeId = Code.CodeId
        LEFT JOIN CodeHierarchy
            ON posCustomerCode.CodeId = CodeHierarchy.DropCode

WHERE 
    CodeHierarchy.ConditionCode NOT IN (
      SELECT CodeId 
      FROM CustomerCode AS negCustomerCode
      WHERE negCustomerCode.CustId=posCustomerCode.CustId
     )
     OR CodeHierarchy.ConditionCode IS NULL

SQLfiddle

于 2013-04-24T20:25:09.433 回答