MySQL left join right join inner join
好记性不如烂笔头
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并不以谁为基础,它只显示符合条件的记录.
最新文章
- 利用GeoWebCache实现WebGIS地形图展示的缓存优化
- YourSQLDba设置共享路径备份
- Linux系统启动错误 contains a file system with errors, check forced解决方法
- NHibernate系列文章二十三:NHibernate查询之Criteria查询(附程序下载)
- CC1310电源
- pentaho cde 选择性的显示多列数据
- 2-SAT 问题
- ci 基础知识
- 在html使用a标签 直接下载图片 不通过后台实现直接下载
- Java NIO之内存映射文件——MappedByteBuffer
- 用C#语言编写:数组分析器
- mongodb监控工具mongostat
- UNIX网络编程——套接字选项(SO_RCVBUF和SO_SNDBUF)
- (转)JavaWeb学习之Servlet(四)----ServletConfig获取配置信息、ServletContext的应用
- 在Eclipse中使用Maven jetty的debug模式
- Delphi如何找到出错行的行数!!
- Delphi的子类化控件消息, 消息子类化
- Linux at 定时任务
- Python网络爬虫-Scrapy框架
- 望岳物业App开发过程记录
热门文章
- iOS 严重问题解释(crash)
- vmware centos7系统虚拟机复制到其他电脑后不能联网问题解决
- mysql性能监控qps,tps,iops
- C++开发--在Visual Studio2013中使用boost::split()编译过程中出现error C4996
- 解决“Connection to https://dl-ssl.google.com refused”问题
- Matlab——filter函数用法
- window策略设置
- 《转》python学习(10)-集合
- 分布式实时日志系统(二) 环境搭建之 flume 集群搭建/flume ng资料
- * 和->; 优先级