一:连接查询(外链接outer和内链接inner)

  连接查询是另一种类型的多表查询。连接查询对多个表进行JOIN运算,简单地说,就是先确定一个主表作为结果集,然后,把其他表的行有选择性地“连接”在主表结果集上。

  语法:两个表的连接(left join table1 on 。。。 默认就是外链接即 left outer join table1 on 。。。)

  SELECT t1.*,t2.* FROM t1 (INNER | LEFT | RIGHT) JOIN t2 ON t1.column1 = t2.column2;

例如: 当使用外链接查询时 例如 SELECT * FROM classes c LEFT JOIN  teacher t  ON c.`id` = t.`class_id` ;

  分析; 以左边的表为主表(即classes表),查询on后面符合条件的teacher表,

      如果关联表中没有符合(主表)条件的,主表后面的以null填充后面的数据(如下)   

id    name    idd    class_id    name
2 二班 2 2 teacher222
2 二班 3 2 teacher222
3 三班 null null null
4 四班 null null null

如何消除为null的数据(即使用外链接来达到内连接的效果)

SELECT * FROM classes c LEFT JOIN  teacher t  ON c.`id` = t.`class_id` WHERE t.`class_id` IS NOT NULL; ()
SELECT * FROM classes c LEFT JOIN teacher t ON c.`id` = t.`class_id` WHERE t.`class_id` = c.`id`; (通过where 相等)
SELECT * FROM classes c INNER JOIN teacher t ON c.`id` = t.`class_id`; (内连接)

对于连接查询有时我们比较容易混淆结果,一下是借鉴廖雪峰老师的图片来解释连接查询的结果,对我个人而言还是比较清晰的,希望对大家也有帮助

************************对于这么多种JOIN查询,到底什么使用应该用哪种呢?其实我们用图来表示结果集就一目了然了*******************。

此图是参考廖雪峰老师的教程,讲的很好https://www.liaoxuefeng.com/wiki/001508284671805d39d23243d884b8b99f440bfae87b0f4000/001509167103179399448cb200549bdab7651a5e9167597000

INNER JOIN  .....ON .....查询连个表的交集,默认会把 不符合条件的数据去除

************************************************************************外链接查询((left|right) [outer 默认参数 join table1 on condition)默认阐述就是outer   故我们常用的连接查询都是外链接查询****************

LEFT JOIN .....ON ....左连接查询(外链接),以左表为基表查询关联表,当主表中的数据没有和关联表中的数据对应时,主表后的字段会被null填充。

参考: RIGHT JOIN ....ON ....右连接查询。参考左连接查询

FULL OUTER JOIN则是选出左右表都存在的记录:(不知道为啥测试不生效)

二 :连接查询中的交叉(CROSS)查询

  语法: 如果table_reference项目列表中的每个逗号被视为等同于内部联接

SELECT * FROM t1 LEFT JOIN (t2, t3, t4)
ON (t2.a = t1.a AND t3.b = t1.b AND t4.c = t1.c) 相当于(把,换成了CROSS JOIN )
SELECT * FROM t1 LEFT JOIN (t2 CROSS JOIN t3 CROSS JOIN t4)
ON (t2.a = t1.a AND t3.b = t1.b AND t4.c = t1.c)

例如sql:交叉查询

   SELECT * FROM classes c LEFT JOIN ( teacher t ,students s ) ON c.`id` = s.`class_id` AND c.`id` = t.`class_id`;  ()

结果:

类比sql :(左外连接查询)

    SELECT * FROM classes c LEFT JOIN  teacher t ON c.`id`=t.`class_id` LEFT JOIN students s ON c.`id`=s.`class_id`;

结果:

通过对比左外查询3个表的内容我分析如下

交叉查询:是先以主表为基表(from 后的表),查询join 后的多表根据on 后面的条件,若on后的条件全部成立才显示后面表的内容,若有不成立的则不显示。

     基表后不满足条件的数据,则填充为null

注意与多表联合的差别

备注:

  1.JOIN优先级高于逗号运算符(,),因此连接表达式 t1, t2 JOIN t3被解释为 (t1, (t2 JOIN t3)),而不是((t1, t2) JOIN t3)。这会影响使用ON子句的语句, 因为该子句只能引用连接操作数中的列,并且优先级会影响对这些操作数的解释。

mysql之select语法的更多相关文章

  1. MySQL(九)之数据表的查询详解(SELECT语法)一

    这一篇是MySQL中的重点也是相对于MySQL中比较难得地方,个人觉得要好好的去归类,并多去练一下题目.MySQL的查询也是在笔试中必有的题目.希望我的这篇博客能帮助到大家! 重感冒下的我,很难受!k ...

  2. MySQL SELECT语法(二)SELECT...INTO语法

    源自MySQL 5.7 官方手册 SELECT...INTO Syntax 一.SELECT...INTO介绍 SELECT...INTO用来将查询结果存储在变量或者写入文件中. SELECT ... ...

  3. MySQL创建索引语法

    1.介绍: 所有mysql索引列类型都可以被索引,对来相关类使用索引可以提高select查询性能,根据mysql索引数,可以是最大索引与最小索引,每种存储引擎对每个表的至少支持16的索引.总索引长度为 ...

  4. MySQL 使用SELECT ... FOR UPDATE 做事务写入前的确认(转)

    Select…For Update语句的语法与select语句相同,只是在select语句的后面加FOR UPDATE [NOWAIT]子句. 该语句用来锁定特定的行(如果有where子句,就是满足w ...

  5. MySQL的一些语法总结

    初学MySQL,今天遇到了一个问题,然后汇总了一下MySQL的一些语法 1. date和datetime类型是不同的 date只记录日期(包括年月日),datetime记录日期和时间(包括年月日时分秒 ...

  6. sql点滴41—mysql常见sql语法

    原文:sql点滴41-mysql常见sql语法 ALTER TABLE:添加,修改,删除表的列,约束等表的定义. 查看列:desc 表名; 修改表名:alter table t_book rename ...

  7. [mysql使用(2)] mysql的一些语法与Oracle的差别

    一.表空间 mysql的表空间有共享表空间和独占表空间,独占表空间,其实就是一张表一个表空间,其实也就是一张表一个数据文件,共享表空间似乎有点类似oracle的表空间,不同的表可以保存在同一个数据文件 ...

  8. mysql进阶(四)mysql中select

    mysql中select * for update 注:  FOR UPDATE 仅适用于InnoDB,且必须在事务区块(BEGIN/COMMIT)中才能生效. 作用 锁定该语句所选择到的对象.防止在 ...

  9. Mysql索引详细语法

    索引相关命令 - 查看表结构 desc 表名 - 查看生成表的SQL show create table 表名 - 查看索引 show index from 表名 - 查看sql执行时间 set pr ...

随机推荐

  1. scrapy爬虫框架处理流程简介

    1.SPIDERS的yeild将request发送给ENGIN2.ENGINE对request不做任何处理发送给SCHEDULER3.SCHEDULER( url调度器),生成request交给ENG ...

  2. SOA的理解

    SOA架构的概念网上一大堆,笔者也没有发现一个准确.公认的定义.不过笔者在贴吧了发了一个比较好的解释,能够帮助理解: 一个产品有PC端.iOS端.Android端,有个数据查询的功能.传统的设计方法就 ...

  3. 数组中出现次数超过一半的数字(python)

    题目描述 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2. ...

  4. matplotlib坐标轴的一些操作

  5. Failed to resolve:com.android.support:appcompat-v7:报错处理

    既然是版本问题,那就的先去了解自己的电脑安装的SDK工具版本,点开SDK Manager图标,然后选中Updates就可以看到了 这里我的 sdk 工具版本就是26.1.1了 报错是因为自己的andr ...

  6. object references an unsaved transient instance save the transient instance before flushing

    object references an unsaved transient instance save the transient instance before flushing 对象引用未保存的 ...

  7. swift 监测内存泄漏 MLeaksFinder

    使用MLeaksFinder检测项目内存泄露总结 https://www.cnblogs.com/ocarol/p/5288497.html

  8. [leetcode]65. Valid Number 有效数值

    Validate if a given string can be interpreted as a decimal number. Some examples:"0" => ...

  9. 47-java 排列组合

    import java.util.HashSet; public class Main1 { public static int ys = 0; public static int ys2 = 0; ...

  10. ELK+SpringBoot+Logback离线安装及配置

    ELK+SpringBoot+Logback 离线安装及配置 版本 v1.0 编写时间 2018/6/11 编写人 xxx     目录 一. ELK介绍2 二. 安装环境2 三. Elasticse ...