2016-05-13 12 views
-1

私は、特定のサイトのMEMBERSテーブルから見込み客(Pの関係)を選択する必要がある状況があります。しかし、私がこれらの人を選ぶとき、私はそれらの見込み客の2つのグループを除外する必要があります。これらのグループのそれぞれは、MEMBERUDFSという別のテーブルにエントリを持っています。 MEMBERSテーブルのすべてのエントリがMEMBERUDFSテーブルにエントリを持つわけではありません。したがって、2つの「NOT IN」サブクエリを使用してメインクエリからこれらのグループを除外しようとしましたが、それは機能していないようです。私は、次のクエリで除外グループを分離することができる午前:SQLがサブでないクエリ

SELECT MEMBERS_1.memid 
FROM MEMBERS AS MEMBERS_1 
JOIN SITES AS SITES_1 ON MEMBERS_1.siteid = SITES_1.siteid 
LEFT JOIN MEMBERUDFS AS MEMBERUDFS_1 ON MEMBERS_1.memid = MEMBERUDFS_1.memid 
JOIN MEMBERUDFSETUPS AS MEMBERUDFSETUPS_1 ON MEMBERUDFS_1.udfid = MEMBERUDFSETUPS_1.udfid 
WHERE (MEMBERS_1.relationship = 'P') 
    AND (MEMBERS_1.email <> '') 
    AND (MEMBERUDFS_1.udfid = '26') 
    AND (MEMBERUDFS_1.udfvalue = 'No') 
    AND (MEMBERS_1.entrydate < DATEADD(DAY, -6, GETDATE())) 
    AND (MEMBERS_1.siteid = @rvSite) 

そして、このクエリ:

SELECT MEMBERS_2.memid 
FROM MEMBERS AS MEMBERS_2 
JOIN SITES AS SITES_2 ON MEMBERS_2.siteid = SITES_2.siteid 
LEFT JOIN MEMBERUDFS AS MEMBERUDFS_2 ON MEMBERS_2.memid = MEMBERUDFS_2.memid 
JOIN MEMBERUDFSETUPS AS MEMBERUDFSETUPS_2 ON MEMBERUDFS_2.udfid = MEMBERUDFSETUPS_2.udfid 
WHERE (MEMBERS_2.relationship = 'P') 
    AND (MEMBERS_2.email <> '') 
    AND (MEMBERUDFS_2.udfid = '25') 
    AND (MEMBERUDFS_2.udfvalue = 'Yes') 
    AND (MEMBERS_2.entrydate < DATEADD(DAY, -21, GETDATE())) 
    AND (MEMBERS_2.siteid = @rvSite) 

は、これは私が一緒に入れていたものですが、それは、二つのSUBQUERYのグループを排除しません。

SELECT MEMBERS.scancode, 
     MEMBERS.memid, 
     MEMBERS.fname, 
     MEMBERS.lname, 
     MEMBERS.relationship, 
     MEMBERS.status, 
     MEMBERS.email, 
     MEMBERS.entrydate, 
     SITES.sitename 
FROM MEMBERS 
JOIN SITES ON MEMBERS.siteid = SITES.siteid 
WHERE (MEMBERS.relationship = 'P') 
    AND (MEMBERS.email <> '') 
    AND (MEMBERS.siteid = @rvSite) 
    AND (MEMBERS.memid NOT IN (
     SELECT MEMBERS_1.memid 
     FROM MEMBERS AS MEMBERS_1 
     JOIN SITES AS SITES_1 ON MEMBERS_1.siteid = SITES_1.siteid 
     LEFT JOIN MEMBERUDFS AS MEMBERUDFS_1 ON MEMBERS_1.memid = MEMBERUDFS_1.memid 
     JOIN MEMBERUDFSETUPS AS MEMBERUDFSETUPS_1 ON MEMBERUDFS_1.udfid = MEMBERUDFSETUPS_1.udfid 
     WHERE (MEMBERS_1.relationship = 'P') 
      AND (MEMBERS_1.email <> '') 
      AND (MEMBERUDFS_1.udfid = '26') 
      AND (MEMBERUDFS_1.udfvalue = 'No') 
      AND (MEMBERS_1.entrydate < DATEADD(DAY, -6, GETDATE())) 
      AND (MEMBERS_1.siteid = @rvSite)) 
    ) 
    AND (MEMBERS.memid NOT IN (
     SELECT MEMBERS_2.memid 
     FROM MEMBERS AS MEMBERS_2 
     JOIN SITES AS SITES_2 ON MEMBERS_2.siteid = SITES_2.siteid 
     LEFT JOIN MEMBERUDFS AS MEMBERUDFS_2 ON MEMBERS_2.memid = MEMBERUDFS_2.memid 
     JOIN MEMBERUDFSETUPS AS MEMBERUDFSETUPS_2 ON MEMBERUDFS_2.udfid = MEMBERUDFSETUPS_2.udfid 
     WHERE (MEMBERS_2.relationship = 'P') 
      AND (MEMBERS_2.email <> '') 
      AND (MEMBERUDFS_2.udfid = '25') 
      AND (MEMBERUDFS_2.udfvalue = 'Yes') 
      AND (MEMBERS_2.entrydate < DATEADD(DAY, -21, GETDATE())) 
      AND (MEMBERS_2.siteid = @rvSite)) 
    ) 

すべてのヘルプはあなたがちょうどあなたのwherを再生する必要があり

+2

実際にコードフォーマッタを使用する必要があります。あなたのSQLを持っている方法 - それは混乱した混乱です。 – Leptonator

+1

インデントの作業を検討してください。また、実際の問題と目的の出力を知る必要があります。あなたのテーブルのいくつかのサンプル行は素晴らしいでしょう。 – Sturgus

+0

おそらくあなたは[Left Excluding JOIN](http://www.codeproject.com/Articles/33052/Visual-Representation-of-SQL-Joins)のいくつかのバリエーションを望んでいるでしょう。 –

答えて

0

をいただければ幸いですe節...

AND (MEMBERS.memid NOT IN (
    SELECT MEMBERS_1.memid 
    FROM MEMBERS AS MEMBERS_1 
    JOIN SITES AS SITES_1 ON MEMBERS_1.siteid = SITES_1.siteid 
    LEFT JOIN MEMBERUDFS AS MEMBERUDFS_1 ON MEMBERS_1.memid = MEMBERUDFS_1.memid 
    JOIN MEMBERUDFSETUPS AS MEMBERUDFSETUPS_1 ON MEMBERUDFS_1.udfid = MEMBERUDFSETUPS_1.udfid 
    WHERE (MEMBERS_1.relationship = 'P') 
     AND (MEMBERS_1.email <> '') 
     AND (MEMBERS_1.siteid = @rvSite) 
     AND (((MEMBERUDFS_1.udfid = '26') AND (MEMBERUDFS_1.udfvalue = 'No') AND (MEMBERS_1.entrydate < DATEADD(DAY, -6, GETDATE()))) OR 
      ((MEMBERUDFS_1.udfid = '25') AND (MEMBERUDFS_1.udfvalue = 'Yes') AND (MEMBERS_1.entrydate < DATEADD(DAY, -21, GETDATE())))) 
関連する問題