关于SQL数据库中cross join 和inner join用法上的区别? SQL中inner join,outer join和cros...

\u5173\u4e8eSQL\u6570\u636e\u5e93\u4e2dcross join \u548cinner join\u7528\u6cd5\u4e0a\u7684\u533a\u522b

\u5173\u4e8eSQL\u6570\u636e\u5e93\u4e2dcross join \u548cinner join\u7528\u6cd5\u4e0a\u7684\u533a\u522b
\u4e3e\u4e2a\u7b80\u5355\u7684\u4f8b\u5b50\u5427\uff0c\u4ece\u7ed3\u679c\u6765\u7406\u89e3\u6bd4\u8f83\u5177\u4f53\u4e9b\u3002
a\u8868
name sex
\u5f20\u4e09 \u7537
\u674e\u56db \u5973

b\u8868
name age
\u674e\u56db 30
\u738b\u4e94 23

1\\u5168\u5916\u8fde\u63a5
select a.name,a.sex,b.name,b.age
from a full outer join b on a.name=b.name
\u7ed3\u679c\u5982\u4e0b\uff0c
name sex name age
\u5f20\u4e09 \u7537 NULL NULL
\u674e\u56db \u5973 \u674e\u56db 30
NULL NULL \u738b\u4e94 23
\u5173\u8054\u5b57\u6bb5name\uff0c\u5de6\u8868\u6709\u800c\u53f3\u8868\u6ca1\u6709\u7684\uff0c\u5982\u5f20\u4e09\uff0cb.name,b.age\u90fd\u4e3aNULL\uff0c\u52a0\u4e0a\u5de6\u53f3\u4e24\u8fb9\u90fd\u6709\u7684\u5c31\u662f\u5de6\u8fde\u63a5\u7684\u7ed3\u679c;\u800c\u53f3\u8868\u6709\u800c\u5de6\u8868\u8868\u6ca1\u6709\u7684\uff0c\u5982\u738b\u4e94\uff0ca.name,a.sex\u90fd\u4e3aNULL\uff0c\u52a0\u4e0a\u5de6\u53f3\u4e24\u8fb9\u90fd\u6709\u7684\u5c31\u662f\u53f3\u8fde\u63a5\u7684\u7ed3\u679c;\u5de6\u53f3\u4e24\u8fb9\u90fd\u6709\u7684\u5982\uff0c\u674e\u56db\uff0c\u8fd9\u5c31\u662f\u5185\u8fde\u63a5\u3002

\u4f7f\u7528join\u8fde\u8868\uff0c\u7f3a\u9677\u7684\u60c5\u51b5\u4e0b\u662finner join,\u5f00\u53d1\u4e2d\u4f7f\u7528\u7684left join\u548cright join\u5c5e\u4e8eouter join\uff0couter join\u8fd8\u5305\u62ecfull join
\u73b0\u6709\u4e24\u5f20\u8868\uff0cTable A \u662f\u5de6\u8fb9\u7684\u8868\u3002Table B \u662f\u53f3\u8fb9\u7684\u8868\u3002\u5176\u5404\u6709\u56db\u6761\u8bb0\u5f55\uff0c\u5176\u4e2d\u6709\u4e24\u6761\u8bb0\u5f55name\u662f\u76f8\u540c\u7684\uff1a

1.INNER JOIN \u4ea7\u751f\u7684\u7ed3\u679c\u662fAB\u7684\u4ea4\u96c6
SELECT * FROM TableA INNER JOIN TableB ON TableA.name = TableB.name

2.LEFT [OUTER] JOIN \u4ea7\u751f\u8868A\u7684\u5b8c\u5168\u96c6\uff0c\u800cB\u8868\u4e2d\u5339\u914d\u7684\u5219\u6709\u503c\uff0c\u6ca1\u6709\u5339\u914d\u7684\u5219\u4ee5null\u503c\u53d6\u4ee3\u3002SELECT * FROM TableA LEFT OUTER JOIN TableB ON TableA.name = TableB.name

3.RIGHT [OUTER] JOIN \u4ea7\u751f\u8868B\u7684\u5b8c\u5168\u96c6\uff0c\u800cA\u8868\u4e2d\u5339\u914d\u7684\u5219\u6709\u503c\uff0c\u6ca1\u6709\u5339\u914d\u7684\u5219\u4ee5null\u503c\u53d6\u4ee3\u3002
SELECT * FROM TableA RIGHT OUTER JOIN TableB ON TableA.name = TableB.name\u56fe\u6807\u5982left join\u7c7b\u4f3c\u3002

4.FULL [OUTER] JOIN \u4ea7\u751fA\u548cB\u7684\u5e76\u96c6\u3002\u5bf9\u4e8e\u6ca1\u6709\u5339\u914d\u7684\u8bb0\u5f55\uff0c\u5219\u4f1a\u4ee5null\u505a\u4e3a\u503c\u3002SELECT * FROM TableA FULL OUTER JOIN TableB ON TableA.name = TableB.name \u53ef\u4ee5\u901a\u8fc7is NULL\u5c06\u6ca1\u6709\u5339\u914d\u7684\u503c\u627e\u51fa\u6765\uff1aSELECT * FROM TableA FULL OUTER JOIN TableB ON TableA.name = TableB.nameWHERE TableA.id IS null OR TableB.id IS null


5. CROSS JOIN \u628a\u8868A\u548c\u8868B\u7684\u6570\u636e\u8fdb\u884c\u4e00\u4e2aN*M\u7684\u7ec4\u5408\uff0c\u5373\u7b1b\u5361\u5c14\u79ef\u3002\u5982\u672c\u4f8b\u4f1a\u4ea7\u751f4*4=16\u6761\u8bb0\u5f55\uff0c\u5728\u5f00\u53d1\u8fc7\u7a0b\u4e2d\u6211\u4eec\u80af\u5b9a\u662f\u8981\u8fc7\u6ee4\u6570\u636e\uff0c\u6240\u4ee5\u8fd9\u79cd\u5f88\u5c11\u7528\u3002SELECT * FROM TableA CROSS JOIN TableB

SQL数据库中cross join 和inner join区别为:连接不同、条件筛选不同、语法不同。

一、连接不同

1、cross join :cross join将A表的所有行分别与B表的所有行进行连接,返回的记录数为两个表的记录数乘积。

2、inner join:inner join组合两个表中的记录,只有公共字段之中有相符的值才进行连接。

二、条件筛选不同

1、cross join :cross join不能在连接时进行条件筛选。

2、inner join:inner join可以通过on关键字,在连接时进行条件筛选。

三、语法不同

1、cross join :cross join 的语法不加on关键字,为SELECT * FROM table1 CROSS JOIN table2。

2、inner join:inner join的语法可以加on关键字,为SELECT * FROM table1 INNER JOIN table2 ON table1.field1  = table2.field2。



=====
举个简单的例子吧,从结果来理解比较具体些。
a表
name sex
张三 男
李四 女

b表
name age
李四 30
王五 23

1\全外连接
select a.name,a.sex,b.name,b.age
from a full outer join b on a.name=b.name
结果如下,
name sex name age
张三 男 NULL NULL
李四 女 李四 30
NULL NULL 王五 23
关联字段name,左表有而右表没有的,如张三,b.name,b.age都为NULL,加上左右两边都有的就是左连接的结果;而右表有而左表表没有的,如王五,a.name,a.sex都为NULL,加上左右两边都有的就是右连接的结果;左右两边都有的如,李四,这就是内连接。相见如下
2\左
select a.name,a.sex,b.name,b.age
from a left outer join b on a.name=b.name
结果如下
name sex name age
张三 男 NULL NULL
李四 女 李四 30
2\右
select a.name,a.sex,b.name,b.age
from a right outer join b on a.name=b.name
结果如下
name sex name age
李四 女 李四 30
NULL NULL 王五 23
3\内联
select a.name,a.sex,b.name,b.age
from a inner join b on a.name=b.name
结果如下
name sex name age
李四 女 李四 30
4\交叉
select a.name,a.sex,b.name,b.age
from a cross join b on a.name=b.name
结果如下
name sex name age
张三 男 李四 30
李四 女 王五 23
张三 男 王五 23
李四 女 李四 30

其实不需要那么麻烦的,只要把查询的语句搞出来就可以了

扩展阅读:microsoft sql server ... 五个常见的数据库软件 ... 数据库备份的三种方法 ... 常见的nosql数据库 ... 四种nosql数据库 ... 最简单的nosql数据库 ... sql和python哪个难学 ... sql server profiler ... sql server 2008 ...

本站交流只代表网友个人观点,与本站立场无关
欢迎反馈与建议,请联系电邮
2024© 车视网