微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

不带外部联接关键字的sql查询

如何解决不带外部联接关键字的sql查询

| 是否可以在您知道必须使用左外部联接的地方编写一个SQL查询。但是不能或不允许使用\“外部联接\”关键字 我有两个表沙想从左表中获取具有空值的行...这很简单...但是不应该使用关键字....外部联接....我需要对外在加入自己的逻辑     

解决方法

SELECT Field1 
FROM table1 
WHERE id NOT IN (SELECT id FROM table2)

SELECT Field1 
FROM table1 
WHERE NOT EXISTS (SELECT * FROM table2 where table2.id = table1.id)
这是人们的工作方式,但已过时,并且当前无法正常使用(有时会返回交叉联接而不是左联接),因此不应使用它。我只是告诉您,是为了避免使用此解决方案。
SELECT Field1 
FROM table1,table2 where table1.id *= table2.id
    ,
;WITH t1(c,d) AS
(
SELECT 1,\'A\' UNION ALL 
SELECT 2,\'B\'
),t2(c,e) AS
(
SELECT 1,\'C\' UNION ALL 
SELECT 1,\'D\' UNION ALL 
SELECT 3,\'E\'
)

SELECT t1.c,t1.d,t2.c,t2.e
FROM t1,t2 
WHERE t1.c = t2.c
UNION ALL
SELECT t1.c,NULL,NULL
FROM t1 
WHERE c NOT IN (SELECT c 
                FROM t2 
                WHERE c IS NOT NULL)
退货
c           d    c           e
----------- ---- ----------- ----
1           A    1           C
1           A    1           D
2           B    NULL        NULL          
(相当于)
SELECT t1.c,t2.e
FROM   t1
       LEFT JOIN t2
         ON t1.c = t2.c  
    ,对于SQL Server,您可以仅使用
LEFT JOIN
-
OUTER
是可选的,就像
INSERT
语句中的
INTO
一样。 所有all9都一样。 对于
INNER JOIN
,您可以仅指定不带限定符的ѭ11and,并将其解释为
INNER JOIN
。     ,这将为您提供表A中所有在表B中没有匹配行的行:
SELECT * 
FROM A
WHERE NOT EXISTS (
  SELECT 1
  FROM B
  WHERE A.id = B.id
);
    ,返回两个表中所有匹配的行:
    SELECT a.*,b.* FROM table_a a,table_b b
    WHERE a.key_field = b.key_field
潜在的缺点是不比赛将被跳过。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。