在开始之前,我们创建两个表用于演示将要介绍的其中JOIN类型。

建表

CREATE TABLE `tbl_dept` (   `id` INT(11) NOT NULL AUTO_INCREMENT,   `deptName` VARCHAR(30) DEFAULT NULL,   `locAdd` VARCHAR(40) DEFAULT NULL,   PRIMARY KEY (`id`)) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

七种JOIN

1. A ∩ B

 SELECT < select_list > FROM TableA A INNER JOIN TableB B # 共有 ON A.Key = B.Key

 SELECT < select_list > FROM TableA A LEFT JOIN TableB B ON A.Key = B.Key

 SELECT < select_list > FROM TableA A RIGHT JOIN TableB B ON A.Key = B.Key

 SELECT < select_list > FROM TableA A LEFT JOIN TableB B ON A.Key = B.Key # ON时主表保留 WHERE B.Key IS NULL # 筛选A表数据

 SELECT < select_list > FROM TableA A RIGHT JOIN TableB B ON A.Key = B.Key WHERE A.Key IS NULL

 SELECT < select_list > FROM TableA A FULL OUTER JOIN TableB B ## FULL OUTER 仅oracle支持 ON A.Key = B.Key

 SELECT < select_list > FROM TableA A FULL OUTER JOIN TableB B ON A.Key = B.Key WHERE A.Key IS NULL OR B.Key IS NULL

更多相关文章

  1. Android异步加载图像小结 (含线程池,缓存方法)
  2. android WebView 图片缩放功能小结
  3. Android(安卓)Camera 使用小结
  4. android fragment学习5--fragment扩展 TabLayout非自定义
  5. Android(安卓)电源系列小结s
  6. Android中自定义对话框小结
  7. Android中自定义对话框小结
  8. Android中自定义对话框小结
  9. Android中自定义对话框小结

随机推荐

  1. pdb是什么文件?
  2. C# 中虚方法和抽象方法
  3. C语言变量的定义包括变量存储类型和变量
  4. for循环是先执行循环体语句,后判断表达式
  5. c语言文件读写操作有哪些?
  6. c语言源程序的扩展名是什么?
  7. c语言中switch的用法是什么?
  8. C语言中void是什么意思?
  9. C语言中for语句的执行过程是什么?
  10. c语言中“&&”什么意思?