欢迎来到福编程网,本站提供各种互联网专业知识!
您的位置:网站首页 > 数据库 > MsSql

sql server几种Join的区别测试方法

发布时间:2016-07-10 作者:njshiney 来源:转载
这篇文章主要来介绍下InnerJoin,FullOutJoin,CrossJoin,LeftJoin,RightJoin的区别,需要的朋友可以参考下

主要来介绍下Inner Join , Full Out Join , Cross Join , Left Join , Right Join的区别。

Inner Join:筛选两边都有的记录

Full Out Join:两边都筛选出来,匹配能匹配的,不能匹配的用NULL列出

Cross Join:列出两边所有组合,也称为笛卡尔集 A×B

Left Join:以左边的表为主表,列出主表所有记录,匹配能匹配的,不能匹配的用 NULL列出

Right Join:以右边的表为主表,列出主表所有记录,匹配能匹配的,不匹配的用NULL列出

下面来看代码:

创建测试表:

代码
  1. CREATETABLE CONSUMERS
  2. (
  3. CONSUMER_ID INTNOTNULL,
  4. CONSUMER_NAME VARCHAR(10) NOTNULL
  5. )
  6. CREATETABLE ORDERS
  7. (
  8. CONSUMER_ID INTNOTNULL,
  9. ORDER_ID VARCHAR(10) NOTNULL)

编测试数据

代码
  1. INSERT CONSUMERS VALUES ( 1, 'AA')
  2. INSERT CONSUMERS values ( 2, 'BB')
  3. INSERT CONSUMERS values ( 3, 'CC')
  4. INSERT ORDERS VALUES ( 2, 'O100001')
  5. INSERT ORDERS VALUES ( 3, 'O100002')
  6. INSERT ORDERS VALUES ( 3, 'O100003')
  7. INSERT ORDERS VALUES ( 4, 'O100004')

测试

代码
  1. --Inner Join
  2. --筛选两边都有的记录
  3. SELECT *
  4. FROM ORDERS o INNER JOIN CONSUMERS c
  5. ON o.CONSUMER_ID = c.CONSUMER_ID
  6. --Full Out Join
  7. --两边都筛选出来,匹配能匹配的,不能匹配的用NULL列出
  8. SELECT *
  9. FROM ORDERS o FULL OUTER JOIN CONSUMERS c
  10. ON o.CONSUMER_ID = c.CONSUMER_ID
  11. --Cross Join
  12. --列出两边所有组合,即笛卡尔集A×B
  13. SELECT *
  14. FROM ORDERS o CROSS JOIN CONSUMERS c
  15. --Left Join
  16. --以左边的表为主表,列出主表所有记录,匹配能匹配的,不能匹配的用NULL列出
  17. SELECT *
  18. FROM CONSUMERS c left join ORDERS o
  19. on c .CONSUMER_ID = o .CONSUMER_ID
  20. --Right Join
  21. --以右边的表为主表,列出主表所有记录,匹配能匹配的,不能匹配的用NULL列出
  22. SELECT *
  23. FROM CONSUMERS c RIGHT JOIN ORDERS o
  24. on c .CONSUMER_ID = o .CONSUMER_ID

ok了,具体的大家可以参考全福编程网以前发布的文章。

相关推荐

返回顶部