一.Join语法概述

join 用于多表中字段之间的联系,语法如下:

... FROM table1 INNER|LEFT|RIGHT JOIN table2 ON conditiona

table1:左表;table2:右表。

JOIN 按照功能大致分为如下三类:

INNER JOIN(内连接,或等值连接):取得两个表中存在连接匹配关系的记录。

LEFT JOIN(左连接):取得左表(table1)完全记录,即是右表(table2)并无对应匹配记录。

RIGHT JOIN(右连接):与 LEFT JOIN 相反,取得右表(table2)完全记录,即是左表(table1)并无匹配对应记录。

注意:mysql不支持Full join,不过可以通过UNION 关键字来合并 LEFT JOIN 与 RIGHT JOIN来模拟FULL join.

接下来给出一个列子用于解释下面几种分类。用一下两个表做例子:

+----+------------+-----------------+---------+--------+
| id | time | process | name | result |
+----+------------+-----------------+---------+--------+
| 1 | 2016-08-31 | wait for result | baidu | 1 |
| 2 | 2016-08-25 | haha | tengxun | 1 |
| 3 | 2016-08-31 | jiayou | wangyi | 1 |
| 9 | 2016-08-31 | happy | wangyi | 1 |
+----+------------+-----------------+---------+--------+
+-----+------------+---------+
| id | time | name |
+-----+------------+---------+
| 1 | 2016-08-30 | tengxun |
| 2 | 2016-09-10 | alibaba |
| 8 | NULL | haha |
| 9 | 2016-08-31 | wangyi |
| 100 | 2014-08-06 | 4399 |
+-----+------------+---------+

二.Inner join

内连接,也叫等值连接,inner join产生同时符合A和B的一组数据。

mysql> select * from recuit inner join exam on recuit.id=exam.id;
+----+------------+-----------------+---------+--------+----+------------+---------+
| id | time | process | name | result | id | time | name |
+----+------------+-----------------+---------+--------+----+------------+---------+
| 1 | 2016-08-31 | wait for result | baidu | 1 | 1 | 2016-08-30 | tengxun |
| 2 | 2016-08-25 | haha | tengxun | 1 | 2 | 2016-09-10 | alibaba |
| 9 | 2016-08-31 | happy | wangyi | 1 | 9 | 2016-08-31 | wangyi |
+----+------------+-----------------+---------+--------+----+------------+---------+
3 rows in set (0.00 sec)

三.Left join

left join,(或left outer join:在Mysql中两者等价,推荐使用left join.)左连接从左表(A)产生一套完整的记录,与匹配的记录(右表(B)) .如果没有匹配,右侧将包含null。

mysql> select * from recuit left join exam on recuit.id=exam.id;
+----+------------+-----------------+---------+--------+------+------------+---------+
| id | time | process | name | result | id | time | name |
+----+------------+-----------------+---------+--------+------+------------+---------+
| 1 | 2016-08-31 | wait for result | baidu | 1 | 1 | 2016-08-30 | tengxun |
| 2 | 2016-08-25 | haha | tengxun | 1 | 2 | 2016-09-10 | alibaba |
| 3 | 2016-08-31 | jiayou | wangyi | 1 | NULL | NULL | NULL |
| 9 | 2016-08-31 | happy | wangyi | 1 | 9 | 2016-08-31 | wangyi |
+----+------------+-----------------+---------+--------+------+------------+---------+
4 rows in set (0.00 sec)

四.Right join

mysql> select * from recuit right join exam on recuit.id=exam.id;
+------+------------+-----------------+---------+--------+-----+------------+---------+
| id | time | process | name | result | id | time | name |
+------+------------+-----------------+---------+--------+-----+------------+---------+
| 1 | 2016-08-31 | wait for result | baidu | 1 | 1 | 2016-08-30 | tengxun |
| 2 | 2016-08-25 | haha | tengxun | 1 | 2 | 2016-09-10 | alibaba |
| 9 | 2016-08-31 | happy | wangyi | 1 | 9 | 2016-08-31 | wangyi |
| NULL | NULL | NULL | NULL | NULL | 8 | NULL | haha |
| NULL | NULL | NULL | NULL | NULL | 100 | 2014-08-06 | 4399 |
+------+------------+-----------------+---------+--------+-----+------------+---------+
5 rows in set (0.00 sec)
 

同left join,只不过是保留了表B的项目,表A中没有相对应的项被置为NULL。

五.Cross join

cross join:交叉连接,得到的结果是两个表的乘积,即笛卡尔积

笛卡尔(Descartes)乘积又叫直积。假设集合A={a,b},集合B={0,1,2},则两个集合的笛卡尔积为{(a,0),(a,1), (a,2),(b,0),(b,1), (b,2)}。可以扩展到多个集合的情况。类似的例子有,如果A表示某学校学生的集合,B表示该学校所有课程的集合,则A与B的笛卡尔积表示所有可能的选 课情况。

mysql> select * from recuit cross join exam;
+----+------------+-----------------+---------+--------+-----+------------+---------+
| id | time | process | name | result | id | time | name |
+----+------------+-----------------+---------+--------+-----+------------+---------+
| 1 | 2016-08-31 | wait for result | baidu | 1 | 1 | 2016-08-30 | tengxun |
| 2 | 2016-08-25 | haha | tengxun | 1 | 1 | 2016-08-30 | tengxun |
| 3 | 2016-08-31 | jiayou | wangyi | 1 | 1 | 2016-08-30 | tengxun |
| 9 | 2016-08-31 | happy | wangyi | 1 | 1 | 2016-08-30 | tengxun |
| 1 | 2016-08-31 | wait for result | baidu | 1 | 2 | 2016-09-10 | alibaba |
| 2 | 2016-08-25 | haha | tengxun | 1 | 2 | 2016-09-10 | alibaba |
| 3 | 2016-08-31 | jiayou | wangyi | 1 | 2 | 2016-09-10 | alibaba |
| 9 | 2016-08-31 | happy | wangyi | 1 | 2 | 2016-09-10 | alibaba |
| 1 | 2016-08-31 | wait for result | baidu | 1 | 8 | NULL | haha |
| 2 | 2016-08-25 | haha | tengxun | 1 | 8 | NULL | haha |
| 3 | 2016-08-31 | jiayou | wangyi | 1 | 8 | NULL | haha |
| 9 | 2016-08-31 | happy | wangyi | 1 | 8 | NULL | haha |
| 1 | 2016-08-31 | wait for result | baidu | 1 | 9 | 2016-08-31 | wangyi |
| 2 | 2016-08-25 | haha | tengxun | 1 | 9 | 2016-08-31 | wangyi |
| 3 | 2016-08-31 | jiayou | wangyi | 1 | 9 | 2016-08-31 | wangyi |
| 9 | 2016-08-31 | happy | wangyi | 1 | 9 | 2016-08-31 | wangyi |
| 1 | 2016-08-31 | wait for result | baidu | 1 | 100 | 2014-08-06 | 4399 |
| 2 | 2016-08-25 | haha | tengxun | 1 | 100 | 2014-08-06 | 4399 |
| 3 | 2016-08-31 | jiayou | wangyi | 1 | 100 | 2014-08-06 | 4399 |
| 9 | 2016-08-31 | happy | wangyi | 1 | 100 | 2014-08-06 | 4399 |
+----+------------+-----------------+---------+--------+-----+------------+---------+
20 rows in set (0.00 sec)

六.Full join

mysql不支持full join,可以用right join和left join模拟

mysql> select * from exam left join recuit on exam.id=recuit.id
-> union
-> select * from exam right join recuit on exam.id = recuit.id;
+------+------------+---------+------+------------+-----------------+---------+--------+
| id | time | name | id | time | process | name | result |
+------+------------+---------+------+------------+-----------------+---------+--------+
| 1 | 2016-08-30 | tengxun | 1 | 2016-08-31 | wait for result | baidu | 1 |
| 2 | 2016-09-10 | alibaba | 2 | 2016-08-25 | haha | tengxun | 1 |
| 9 | 2016-08-31 | wangyi | 9 | 2016-08-31 | happy | wangyi | 1 |
| 8 | NULL | haha | NULL | NULL | NULL | NULL | NULL |
| 100 | 2014-08-06 | 4399 | NULL | NULL | NULL | NULL | NULL |
| NULL | NULL | NULL | 3 | 2016-08-31 | jiayou | wangyi | 1 |
+------+------------+---------+------+------------+-----------------+---------+--------+
6 rows in set (0.25 sec)

SQL连接操作的更多相关文章

  1. (修改)oracle11g监听多台主机配置,用pl/sql连接操作多个数据库详解

    很多朋友在开发项目中并不是每个人用一个数据库,而是有单独的一台主机作为开发的数据库服务器,这样,就需要我们的开发人员去连接它. 首先是进入oracle的 Net  Mananger:

  2. php的SQL连接操作的方法

    初学php,于是一开始就在sql(具体点说是mysql)里受挫严重.于是这里记下一些方法. 首先是基本方法.基本方法现在我不用了,所以我就附一下hustoj中的部分吧 基本方法的数据库连接操作: if ...

  3. SQL 连接操作 及 查询分析

  4. 关闭数据库下的所有连接操作 sql存储过程

    use master go )) as begin ),) declare @spid int set @sql='declare getspid cursor for select spid fro ...

  5. SQL 经典回顾:JOIN 表连接操作不完全指南

    ​   2017-02-23 小峰 ITPUB 点击上方“蓝字”可以关注我们哦  |转载自:码农网 |原文链接:www.codeceo.com/article/sql-join-guide.html ...

  6. 【HANA系列】SAP HANA SQL字符串连接操作

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA SQL字符串连 ...

  7. SQL连接

    SQL连接可以分为内连接.外连接.交叉连接. 数据库数据:             book表                                          stu表 1.内连接 ...

  8. SQL用法操作合集

    SQL用法操作合集   一.表的创建 1.创建表 格式: 1 CREATE TABLE 表名 2 (列名 数据类型(宽度)[DEFAULT 表达式][COLUMN CONSTRAINT], 3 ... ...

  9. MySQL 子查询与连接操作笔记

    SQL语句之间是可以进行连接操作的,在一些复杂的数据操作中必须用到连接操作.简单的说就是一个SQL语句的结果可以作为相连接的SQL操作的一部分.SQL结构化查询语句,子查询是指的所有的SQL操作,并非 ...

随机推荐

  1. 极简单的方式序列化sqlalchemy结果集为JSON

    继承 json.JSONEncoder 实现一个针对sqlalchemy返回类型的处理方式. sqlalchemy的返回类型有大都有两种,一种是Model对象,一种是Query集合(只查询部分字段). ...

  2. document.querySelectorAll() 与document.getElementTagName() 的区别

    这个区别我估计大神都不知道,问题源于博主,细节被一个妹子发现的 事情经过是这样 <ul> <li>item</li> <li></li> & ...

  3. 解决CentOS7中文乱码(包括Tomcat日志乱码)问题

    Linux系统中文语言乱码,是很多小伙伴在开始接触Linux时经常遇到的问题,而且当我们将已在Wndows部署好的项目搬到Linux上运行,Tomcat的输出日志中文全为乱码(在Windows上正常) ...

  4. c#Message多功能用法

     1.   当要显示如图3个按钮时,并要获得单击不同按钮的进行不同的相应时,可以在MessageBoxButtons后面添加一个.(应该英文的点,此处为了醒目,用中文代替)可以看到提示框下方需要几个按 ...

  5. Debian 8添加kali更新源并安装metasploit

    一.Debian 8添加kali更新源 中科大kali更新源: deb http://mirrors.ustc.edu.cn/kali kali-rolling main non-free contr ...

  6. 虚幻引擎UE4如何制作可拖动(Drag and Drop)的背包(Scrollbox)

    本教程适合初学者(学习经历已有30天的UE4初学者). 最终效果 由于隐私保护,不想截实际的效果图,下面给出了示意图,左边是背包A,右边是背包B,将其中的子项目从左侧拖往右侧的背包,然后在插入位置放置 ...

  7. webpack2归纳总结

    本文github仓库:https://github.com/Rynxiao/webpack2-learn 从v1迁移到v2 1. 配置类型 在webpack1的时候,主要是通过导出单个object来进 ...

  8. 阿里巴巴2018届应届生在线编程测验-研发工程师C/C++

    刚才去做了阿里巴巴的编程测验,好消息是抽到的题相对别的题简单一些,坏消息是编的太慢了,没有做完. 现在把题目和自己后来编出来的代码贴在这里,供大家参考. 题目: 1. 从命令行输入若干个正整数(大于等 ...

  9. 途虎养车Tuhu商城系统开发

    途虎养车Tuhu商城系统开发,咨询:何经理152-2217-7508(微信同号)途虎养车商城小程序开发,途虎养车商城小程序平台开发,途虎养车商城小程序系统开发. 为什么能做得这么好,里面的门道确实不少 ...

  10. Cocoapods最新安装教程

    一.CocoaPods简介 每种语言发展到一个阶段,就会出现相应的依赖管理工具,例如 Java 语言的 Maven,nodejs 的 npm.随着 iOS 开发者的增多,业界也出现了为 iOS 程序提 ...