数据库在连接两张或以上的表来返回数据时,都会生成一张中间的临时表,然后再将临时表返回给用户
left join,right join,inner join, join 与 on 配合用

select col_name.. from tablename1 [inner | left | right] join tablename2 on on_condition

select col_name.. from tablename1 left join tablename2 on on_condition

CREATE TABLE IF NOT EXISTS `name`(
    pid int(11) unsigned auto_increment,
    name varchar(40) NOT NULL,
    primary key(`pid`)
) ENGINE = MYISAM DEFAULT CHARSET = UTF8;

CREATE TABLE IF NOT EXISTS `sname`(
    id int(11) unsigned NOT NULL AUTO_INCREMENT,
    spid int(11) NOT NULL,
        firstname varchar(40),
    primary key(`id`)
)ENGINE = MYISAM DEFAULT CHARSET=UTF8;

name与sname 中,name.pid 与 sname.spid 相关联

name 表数据:

sname 表数据

执行时当tablename1[(如果在后面单独附加有条件时)符合条件时]全部选择,在tablename2时如果没有相应的数据,则其列都显示为NULL

right join类似,只是角色反过来了

inner join (与 join 相同) 表示两个表都有的数据行

相当于 from tabname1,tabname2 where ? = ?

具体实例如下:

其实就是两表的笛卡尔积
用一个表的一行去乘另一个表的所有行,然后再换到一下行,重复相乘另一个表的所有行,直接这个表结尾
$sql = "select * from name, sname";
$result = mysql_query($sql, $link);
$i = 0;
echo '<table border="1" width="550">';
echo '<tr>';
echo '<th width="40">行号</th>';
echo '<th width="80">name表pid</th>';
echo '<th width="80">name表name</th>';
echo '<th width="80">sname表id</th>';
echo '<th width="100">sname表spid</th>';
echo '<th width="140">sname表firstname</th>';
echo '</tr>';
while($row = mysql_fetch_assoc($result))
{
    $i++;
    echo '<tr>';
    echo '<td>'.$i.'</td>';
    echo '<td>'.$row['pid'].'</td>';
    echo '<td>'.$row['name'].'</td>';
    echo '<td>'.$row['id'].'</td>';
    echo '<td>'.$row['spid'].'</td>';
    echo '<td>'.$row['firstname'].'</td>';
    echo '</tr>';
}
echo '</table>';

结果为:

其实就是选择两边都有的字段,且满足 where 条件
$sql = "select * from name, sname where name.pid = sname.spid";
$result = mysql_query($sql, $link);
$i = 0;
echo '<table border="1" width="550">';
echo '<tr>';
echo '<th width="40">行号</th>';
echo '<th width="80">name表pid</th>';
echo '<th width="80">name表name</th>';
echo '<th width="80">sname表id</th>';
echo '<th width="100">sname表spid</th>';
echo '<th width="140">sname表firstname</th>';
echo '</tr>';
while($row = mysql_fetch_assoc($result))
{
    $i++;
    echo '<tr>';
    echo '<td>'.$i.'</td>';
    echo '<td>'.$row['pid'].'</td>';
    echo '<td>'.$row['name'].'</td>';
    echo '<td>'.$row['id'].'</td>';
    echo '<td>'.$row['spid'].'</td>';
    echo '<td>'.$row['firstname'].'</td>';
    echo '</tr>';
}
echo '</table>';

如果用 join,inner join 结果是一样的,即

$sql = "select * from name (inner) join sname on name.pid = sname.spid"

以下是用 left join

其实就是选择左边所有的数据,如果右边没有与左边相关的就为NULL

$sql = "select * from name left join sname on name.pid = sname.spid";
$result = mysql_query($sql, $link);
$i = 0;
echo '<table border="1" width="550">';
echo '<tr>';
echo '<th width="40">行号</th>';
echo '<th width="80">name表pid</th>';
echo '<th width="80">name表name</th>';
echo '<th width="80">sname表id</th>';
echo '<th width="100">sname表spid</th>';
echo '<th width="140">sname表firstname</th>';
echo '</tr>';
while($row = mysql_fetch_assoc($result))
{
    $i++;
    echo '<tr>';
    echo '<td>'.$i.'</td>';
    echo '<td>'.$row['pid'].'</td>';
    echo '<td>'.$row['name'].'</td>';
    echo '<td>'.$row['id'].'</td>';
    echo '<td>'.$row['spid'].'</td>';
    echo '<td>'.$row['firstname'].'</td>';
    echo '</tr>';
}
echo '</table>';

right join 正好相反

其实就选择右表的所有数据,如果左边没有相关的就为NULL

$sql = "select * from name right join sname on name.pid = sname.spid";
$result = mysql_query($sql, $link);
$i = 0;
echo '<table border="1" width="550">';
echo '<tr>';
echo '<th width="40">行号</th>';
echo '<th width="80">name表pid</th>';
echo '<th width="80">name表name</th>';
echo '<th width="80">sname表id</th>';
echo '<th width="100">sname表spid</th>';
echo '<th width="140">sname表firstname</th>';
echo '</tr>';
while($row = mysql_fetch_assoc($result))
{
    $i++;
    echo '<tr>';
    echo '<td>'.$i.'</td>';
    echo '<td>'.$row['pid'].'</td>';
    echo '<td>'.$row['name'].'</td>';
    echo '<td>'.$row['id'].'</td>';
    echo '<td>'.$row['spid'].'</td>';
    echo '<td>'.$row['firstname'].'</td>';
    echo '</tr>';
}
echo '</table>';

union把选择的数据组合返回
AS:

select colname1...
union [ALL | DISTINCT]
select colname2....

union 一般要求选择的字段数目相同,对应的字段类型也得相同.

在mysql 5.1版本中
如果union连接的字段数不相等,则报错,如果字段数相同,字段类型不同,以返回的结果全部填充在第一个 select 的字段中

转载于:https://www.cnblogs.com/lin3615/p/3543618.html

left join, right join , inner join, join, union的意义相关推荐

  1. mysql left join和or_Case:MySQL使用left join的时候or改写成union可以提高效率

    Case:MySQL使用left join的时候or改写成union可以提高效率 发布时间:2020-07-29 02:29:13 来源:51CTO 阅读:1501 作者:Darren_Chen (1 ...

  2. 【Transact-SQL】SQL Server自动把left join自动转化为inner join、以及关联时的数据重复问题...

    1.SQL Server自动把left join自动转化为inner join的问题: 下面的两个语句都是left join的,但是一个却转化成了 inner join drop table a,B ...

  3. mysql join 与 cross join 效率_浅析Mysql Join语法以及性能优化

    在讲MySQL的Join语法前还是先回顾一下联结的语法,呵呵,其实连我自己都忘得差不多了,那就大家一起温习吧,这里我有个比较简便的记忆方法,内外联结的区别是内联结将去除所有不符合条件的记录,而外联结则 ...

  4. mysql+join的原理,Mysql连接join查询原理知识点

    Mysql连接join查询原理知识点 Mysql连接(join)查询 1.基本概念 将两个表的每一行,以"两两横向对接"的方式,所得到的所有行的结果. 假设: 表A有n1行,m1列 ...

  5. mysql outer join的用法_MySQL中join的用法

    JOIN的含义就如英文单词"join"一样,连接两张表,大致分为内连接,外连接,右连接,左连接,自然连接.这里描述先甩出一张用烂了的图,然后插入测试数据. 笛卡尔积:CROSS J ...

  6. mysql inner join_MySQL JOIN 语法说明与 INNER JOIN 语法用法实例

    MySQL JOIN 语法概述 SQL(MySQL) JOIN 用于根据两个或多个表中的字段之间的关系,从这些表中得到数据. JOIN 通常与 ON 关键字搭配使用,基本语法如下: ... FROM ...

  7. java fork join原理_细说Fork/Join框架

    什么是Fork/Join框架? Fork/Join框架是JDK1.7提供的一个用于并行执行任务的框架,是一个把大任务分割成若干小任务,最终汇总每个小任务结果后得到大任务结果的框架.Fork就是把一个大 ...

  8. mysql right join实例_MySQL表LEFT JOIN左连接与RIGHT JOIN右连接的实例教程

    LEFT JOIN 语法用法与实例MySQL LEFT JOIN 语法 SQL(MySQL) LEFT JOIN 会取得左表(table1)全部记录,即使右表(table2)并无对应匹配记录.LEFT ...

  9. Python中join()方法和os.path.join()方法

    join() 方法: 描述:join()方法用于将序列中的元素以指定的字符连接成一个新的字符串 语法:x.join(y) y: 可迭代对象,对象内的元素必须是字符串类型.对象可以是字符串.元组.列表和 ...

  10. Mysql 优化器内部JOIN算法hash join Nestloopjoin及classic hash join CHJ过程详解

    Mysql hash join之classic hash join CHJ过程详解 hash join的历史 优化器里的hash join算法在SQL Server.Oracle.postgress等 ...

最新文章

  1. 80个Python经典资料(教程+源码+工具)汇总——下载目录
  2. TreeMap源码分析
  3. 《Ext JS 高级程序设计》的目录与样张
  4. magent实现memcached集群的一个问题
  5. wxpython嵌套panel布局的一个问题
  6. 【项目管理】敏捷宣言
  7. 57张PPT彻底搞清楚区块链技术。。
  8. 【codeforces 507E】Breaking Good
  9. TreeView 操作应用
  10. 收集分享有用的注册表项
  11. mysql日志文件转存_【转】Mysql日志文件
  12. Laravel 成为最佳 PHP 框架的 14 个理由!
  13. iOS 开发 - 绘制辉光效果
  14. 数据挖掘技术之关联分析
  15. 用户行为分析面面观之三
  16. Java 静态模块和构造方法
  17. Java中方法与数组
  18. zabbix 监控项自动发现过滤_zabbix怎么使用自动发现添加新监控项
  19. 淘宝店铺基础版全屏装修步骤及代码,已经经过测试
  20. errMsg: “checkJsApi:ok“

热门文章

  1. 如何将安卓数据同步到Mac电脑上
  2. Mac电脑共享“公共文件夹”以外的文件夹的设置教程
  3. 在苹果Mac上找不到文件存储位置怎么办?
  4. M1 Mac 是否入手,先了解这些常用软件兼容性!!
  5. 看雪CTF.TSRC 2018 团队赛 第六题 『追凶者也』 解题思路
  6. 第十三章:位图(八)
  7. Dapper.net 入门demo 轻量级ORM框架
  8. [Python爬虫] 之二十五:Selenium +phantomjs 利用 pyquery抓取今日头条网数据
  9. 【转】一些 SQLite技巧
  10. 如何将 UbuntuServer 安全的升级