好记性不如烂笔头

sql连接共三种:内连接,外连接,交叉连接。

内连接包含:等值连接,不等值连接,自然连接

外连接包含:左连接(左外连接),右连接(右外连接)

具体理论见我的博文http://blog.csdn.net/jdfkldjlkjdl/article/details/41485127

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

下面是实例介绍,相信这样更直观。

现有A和B两个表

表A记录如下: 
aID         aNum 
1            a20050111 
2            a20050112 
3            a20050113 
4            a20050114 
5            a20050115 
表B记录如下: 
bID         bName 
1            2006032401 
2            2006032402 
3            2006032403 
4            2006032404 
8            2006032408 
1.left join(左联接) 
SELECT * FROM a LEFT JOIN b ON a.aID =b.bID 
结果如下: 
aID              aNum              bID            bName 
1                 a20050111     1               2006032401 
2                 a20050112     2               2006032402 
3                 a20050113     3               2006032403 
4                 a20050114     4               2006032404 
5                 a20050115    NULL         NULL 
(所影响的行数为 5 行) 
结果说明: 
left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的. 
换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录(例子中为: A.aID = B.bID). B表记录不足的地方均为NULL. 
2.right join(右联接) 
SELECT * FROM a RIGHT JOING b ON a.aID = b.bID 
结果如下: 
aID              aNum              bID            bName 
1                 a20050111     1               2006032401 
2                 a20050112     2               2006032402 
3                 a20050113     3               2006032403 
4                 a20050114     4               2006032404 
NULL           NULL              8               2006032408 
(所影响的行数为 5 行) 
结果说明: 
仔细观察一下,就会发现,和left join的结果刚好相反,这次是以右表(B)为基础的,A表不足的地方用NULL填充. 
3.inner join(相等联接或内联接) 
SELECT * FROM a INNER JOIN b ON a.aID =b.bID 
等同于以下SQL句: 
SELECT * FROM a,b WHERE a.aID = b.bID 
结果如下: 
aID             aNum              bID            bName 
1                a20050111     1                2006032401 
2                a20050112     2                2006032402 
3                a20050113     3                2006032403 
4                a20050114     4                2006032404 
结果说明: 
很明显,这里只显示出了 A.aID = B.bID的记录.这说明inner join并不以谁为基础,它只显示符合条件的记录.

 
 

最新文章

  1. 利用GeoWebCache实现WebGIS地形图展示的缓存优化
  2. YourSQLDba设置共享路径备份
  3. Linux系统启动错误 contains a file system with errors, check forced解决方法
  4. NHibernate系列文章二十三:NHibernate查询之Criteria查询(附程序下载)
  5. CC1310电源
  6. pentaho cde 选择性的显示多列数据
  7. 2-SAT 问题
  8. ci 基础知识
  9. 在html使用a标签 直接下载图片 不通过后台实现直接下载
  10. Java NIO之内存映射文件——MappedByteBuffer
  11. 用C#语言编写:数组分析器
  12. mongodb监控工具mongostat
  13. UNIX网络编程——套接字选项(SO_RCVBUF和SO_SNDBUF)
  14. (转)JavaWeb学习之Servlet(四)----ServletConfig获取配置信息、ServletContext的应用
  15. 在Eclipse中使用Maven jetty的debug模式
  16. Delphi如何找到出错行的行数!!
  17. Delphi的子类化控件消息, 消息子类化
  18. Linux at 定时任务
  19. Python网络爬虫-Scrapy框架
  20. 望岳物业App开发过程记录

热门文章

  1. iOS 严重问题解释(crash)
  2. vmware centos7系统虚拟机复制到其他电脑后不能联网问题解决
  3. mysql性能监控qps,tps,iops
  4. C++开发--在Visual Studio2013中使用boost::split()编译过程中出现error C4996
  5. 解决“Connection to https://dl-ssl.google.com refused”问题
  6. Matlab——filter函数用法
  7. window策略设置
  8. 《转》python学习(10)-集合
  9. 分布式实时日志系统(二) 环境搭建之 flume 集群搭建/flume ng资料
  10. * 和-> 优先级