一:连接查询(外链接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. body标签

    标签(空格分隔): body标签 body标签: 想要在网页上展示出来的内容一定要放在body标签中. 把我们之前那一段HTML代码贴过来,保存到一个HTML格式的文件中. <!DOCTYPE ...

  2. kettle学习笔记(二)——kettle基本使用

    一.子程序功能和启动方式介绍 Spoon.bat: 图形界面方式启动作业和转换设计器. Pan.bat: 命令行方式执行转换. Kitchen.bat: 命令行方式执行作业. Carte.bat: 启 ...

  3. day43 多表查询和pymysql

    复习 增删改查全语法 # 增 insert into db1.t1(字段2, 字段1, ..., 字段n)|省略 values (值2, 值1, ..., 值n)|(值1, 值2, ..., 值n)[ ...

  4. as3.0 当fla里面有TLF文本的时候,加载声音会出现错误

    问题描述 1.现有制作好的mp3加载包,这个包是相对路径 2.如果fla里面没有TLF文本,可以正常运行 解题思路 1.音频的相对路径和加载TLF文本的路径不一样,fla会优先选择TLF文件,这样mp ...

  5. 使用jmail发送短信

    原文链接 https://blog.csdn.net/sdaujsj1/article/details/79248469 pom <!-- https://mvnrepository.com/a ...

  6. 【.Net】 大文件可使用的文本分组统计工具(附带源码,原创)

    本工具可实现的效果: 1.读取大文件(大于1GB) 2.根据分隔符分割后的列分组 3.速度快. 4.处理过程中,可以随时停止处理,操作不卡死. 5.有对当前内存的实时监测,避免过多占用内存,影响系统运 ...

  7. centos 7 安装pip

    1.首先检查centos 有没有安装python-pip 包, >>yum install python-pipnotice:NO package python-pip available ...

  8. vi/vim 文字处理器常用命令

    目录 vi 与vim vi 的三种模式 vi 光标移动 vi 搜索与替换 vi 删除 vi 复制 vi 粘贴 vi 其他 vi 进入编辑模式 vi 命令行命令 vim 附加功能 vi 与vim vi是 ...

  9. windows平台下的oracle ORA-01031的解决方法

    今天下午遇到一个很怪异的问题,在windows平台下sqlplus  / as sysdba登陆数据库,提示权限不足, 当时就纳闷了,sys用户登陆数据库还能权限不足,问题出现了,就开始寻找解决方法呗 ...

  10. String 常用函数

    判断字符串是否包含指定字符str.contains("string"); 查找指定字符索引str.indexOf("s"'); 查找最后出现的字符索引str.i ...