1

我一直在研究如何将我拥有的 UNION 转换为 INTERSECT,但 MS Access 中没有 INTERSECT 关键字。

如果我想要这两个 select 语句的交集而不是它们的 Union,我一直很困惑以下代码如何使用内部连接。

我知道如果我 SELECT DISTINCT 然后使用内部联接,我可以实现我想要的,但 ON 关键字真的让我感到困惑。

我一周前刚开始使用 SQL,所以如果您发现代码有任何其他问题,我会接受所有建设性的批评 :)

SELECT *
FROM (SELECT [Catt].[Name]
FROM [Catt]
WHERE ((([Catt].[Name]) Like "*" & [forms]![Main]![SrchText] & "*") 
AND [forms]![Main]!   [SrchText] IS NOT Null AND [forms]![Main]![SrchText]<>''  )

UNION

SELECT [Catt].[Name]
FROM [Catt]
WHERE  ((([Catt].[Category]) Like [forms]![Main]![Combo7].Value) AND (([forms]![Main]!    [SrchText] IS Null) OR ([forms]![Main]![SrchText]=''))))  AS Query
ORDER BY [Catt].[Name];

谢谢你。

4

1 回答 1

1

尚未对此进行测试,因此您肯定会进行大量 MS Access 特定更改。但我要求您不要通过不必要地在方块中引用每个标识符来混淆查询:

SELECT     DISTINCT title
FROM       (  
            SELECT [Catt].[Name] as title
            FROM   [Catt]
            WHERE  ([Catt].[Name] Like "*" & [forms]![Main]![SrchText] & "*") AND 
                    [forms]![Main]![SrchText] IS NOT Null AND 
                    [forms]![Main]![SrchText] <>''
           ) AS view1

INNER JOIN 

           (   
            SELECT   [Catt].[Name]
            FROM     [Catt]
            WHERE    [Catt].[Category] Like [forms]![Main]![Combo7].Value AND 
                     ([forms]![Main]![SrchText] IS Null OR 
                      [forms]![Main]![SrchText]='')
           ) AS view2 ON view1.title = view2.Name

ORDER BY   view1.title

但基本上这样的事情就可以了..

正如戈登指出的那样编辑

于 2012-05-08T16:32:02.947 回答