SQL的多表连接查询
SQL的多表连接查询
多表连接查询具有两种规范,SQL92和SQL99规范。
SQL92规范支持下列多表连接查询:
(1)等值连接;
(2)非等值连接;
(3)外连接;
(4)广义笛卡尔积;
SQL99规范支持了可读性更好的多表连接语法,并提供了更多类型的连接查询,SQL99规范支持的多表连接如下:
(1)交叉连接;
(2)自然连接;
(3)使用using句子的连接;
(4)全外连接,或左、右外连接。
1.SQL92的连接查询
SQL92多表连接查询语句比较简洁,这种语法把多个数据表放在from之后,多个表之间以逗号隔开;连接条件放在where之后,与查询条件之间用and逻辑运算符连接。如果连接条件要求两列值相等,则称为等值连接,否则称为非等值连接;如果没有任何连接条件,则称为广义笛卡尔积。
SQL92多表连接查询的语法格式:
select column1,column2 ... from table1,table2 ... where join_condition
多表连接查询中可能出现两个或多个列具有相同列名的情况,则需要在这些同名列之间使用表名作为前缀或表别名作为前缀为限制,以避免系统混淆。
所有的列都可以增加表名前缀或者表别名前缀。只是进行单表查询时,绝不会出现同名列,所以系统不会发生混淆,因此省略表名前缀。
(1)查询出所有学生资料以及老师姓名
select s.*,teacher_name #指定多个数据表,并指定表别名 from student_table as s,teacher_table t #使用where指定连接条件 where s.java_teacher = t.teacher_id;
(2)当要求广义笛卡尔积时,where子句后没有任何的条件,广义笛卡尔积的结果会有n*m条记录。只要把where后边的连接条件去掉,则可以得到广义笛卡尔积。
select s.*,teacher_name #指定多个数据表,并指定表的别名 from student_table s,teacher_table t;
(3)非等值连接
select s.*,teacher_name #指定多个数据表,并指定别名 from student_table s,teacher_table t #使用where子句指定连接条件,非等值连接 where s.java_teacher>t.teacher_id;
(4)当需要过滤数据时,可以将过滤条件和连接条件使用and连接起来
select s.*,teacher_name #指定多个数据表,并指定表别名 from student_table s,teacher_table t #使用where指定连接条件,并指定student_name不能为空 where s.java_teacher=t.teacher_id and student_name is not null;
(5)SQL92的外连接就是在连接条件的列名后增加括号包起来的外连接符,当外连接符出现在左边时成为左外连接,出现在右边时称为右外连接。
select s.*,teacher_name from student_table s,teacher_table t #右外连接 where s.java_teacher=t.teacher_id(*);
(6)外连接就是在外连接符所在的表中增加一个“万能行”,这行记录的所有数据都是null,而且该行可以与另一表中所有不满足条件的记录进行匹配,通过这种方式就可以把一个表中的所有记录选出来,不管这些记录是否满足连接条件。
2.SQL99的连接查询
SQL99与SQL92连接查询的原理基本相同,SQL99的可读性更强,在SQL99中,查询用的多个数据表显式使用xxx join连接,不是依次排在from之后,from之后值需要放一个数据表;连接条件不再放在where以后,而是专门提供了连接条件子句。
(1)交叉连接(cross join)
交叉连接实质就是SQL92的广义笛卡尔积,所以交叉连接无需任何连接条件。
select s.*,teacher_name #连接查询的from后只有一个表名 from student_table as s #cross join交叉连接,相当于广义笛卡儿积 cross join teacher_table t;
(2)自然连接(natural join)
自然连接表面上看起来也无需指定连接条件,但natrual join是有连接条件的,natrual join会以两个表中的同名列作为连接条件;如果两个表中没有同名列,则cross join和natrual join完全一样。
select s.*,teacher_name #from后只有一个表名 from student_table s #natrual join 使用两个表中的同名列为连接条件 natrual join teacher_table t;
(3)using子句连接
using子句可以连接一列或者多列,用于显式指定两个表中的同名列作为连接条件。假设两个表中有超过一列的同名列,如果使用natrual join,则会把所有的同名列当成连接条件;使用using子句,就可以显式指定使用那些列名作为连接条件。
select s.*,teacher_name #from后只有一个表名 from student_table s #join连接另一个表 join teacher_table t using(teacher_id);
值得注意的是,如果使用using子句来指定连接条件,则两个表中必须有同名列,否则就会出现错误。
(4)on子句连接
最常用的连接方式,SQL99语法的连接条件放在on子句中指定,而且每个on子句至指定一个连接条件。这意味着:如果进行N表连接,则需要有N-1个join...on对。
#等值查询
select s.*,teacher_name #from后只有一个表名 from student_table s #join连接另一个表 join teacher_table t #使用on来指定连接条件 on s.java_teacher = t.teacher_id;
#非等值查询 select s.*,teacher_name #from后只跟一个表名 from student_table s #join连接另一个表 join teacher_table t #使用on子句指定连接条件 on s.java_teacher<t.teacher_id;
(5)左、右、全外连接
这三种外连接分别使用left[outer]join、right[outer]join和full[outer]join,这三种外连接的连接条件一样通过on子句来指定,既可以是等值连接条件,也可以是非等值连接条件。
右外连接,条件是非等值连接:把右边表中所有不满足条件的记录全部列出;
select s.*,teacher_name #from后只有一个表名 from student_table s #right join 右外连接另一个表 right join teacher_table t #使用on来指定连接条件,使用非等值连接 on s.java_teacher<t.teacher_id;
左外连接,条件是非等值连接:把左边表中所有不满足条件的记录全部列出;
select s.*,teacher_name #from后只有一个表名 from student_table s #left join 右外连接另一个表 left join teacher_table t #使用on来指定连接条件,使用非等值连接 on s.java_teacher>t.teacher_id;
全外连接,条件是等值连接:把两个表中所有不满足连接条件的记录全部列出;
select s.*,teacher_name #from后只有一个表名 from student_table s #full join 右外连接另一个表 full join teacher_table t #使用on来指定连接条件,使用非等值连接 on s.java_teacher=t.teacher_id;
SQL的多表连接查询的更多相关文章
- SQL语句多表连接查询语法
一.外连接 1.左连接 left join 或 left outer join SQL语句:select * from student left join score on student.Num= ...
- SQL多表连接查询(详细实例)
转载博客:joeleo博客(http://www.xker.com/page/e2012/0708/117368.html) 本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:stud ...
- SQL多表连接查询
SQL多表连接查询 本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:student 截图如下: 表2:course 截图如下: (此时这样建表只是为了演示连接SQL语句,当然实际 ...
- oracle(sql)基础篇系列(二)——多表连接查询、子查询、视图
多表连接查询 内连接(inner join) 目的:将多张表中能通过链接谓词或者链接运算符连接起来的数据查询出来. 等值连接(join...on(...=...)) --选出雇员的名字和雇员所 ...
- SQL表连接查询(inner join、full join、left join、right join)
SQL表连接查询(inner join.full join.left join.right join) 前提条件:假设有两个表,一个是学生表,一个是学生成绩表. 表的数据有: 一.内连接-inner ...
- SQL表连接查询
SQL表连接查询(inner join.full join.left join.right join) 表的数据有: 一.内连接-inner jion : 最常见的连接查询可能是这样,查出学生的名字和 ...
- SQL多表连接查询(详细实例)(转)
http://www.xker.com/page/e2012/0708/117368.html select * from student,course where student.ID=course ...
- SQL多表连接查询(具体实例)
本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:student 截图例如以下: 表2:course 截图例如以下: (此时这样建表仅仅是为了演示连接SQL语句.当然实际开发中我们 ...
- oracle(sql)基础篇系列(二)——多表连接查询、子查询、视图
多表连接查询 内连接(inner join) 目的:将多张表中能通过链接谓词或者链接运算符连接起来的数据查询出来. 等值连接(join...on(...=...)) --选出雇员的名字和雇员所在的部门 ...
随机推荐
- Windows Internal Database Service Pack 4 x64 Edition (KB2463332)安装失败
系统是Windows Server 2008 R2,补丁Windows Internal Database Service Pack 4 x64 Edition (KB2463332)总是安装失败,W ...
- LeetCode Fizz Buzz
原题链接在这里:https://leetcode.com/problems/fizz-buzz/ 题目: Write a program that outputs the string represe ...
- Ubuntu 16.04 LTS发布
[Ubuntu 16.04 LTS发布]Ubuntu 16.04 LTS 发布日期已正式确定为 2016 年 4 月 21 日,代号为 Xenial Xerus.Ubuntu16.04 将是非常受欢迎 ...
- chrome新版安装flash控件失败解决方法
今天chrome打开后出现插件过期,之后更新一直安装失败 度娘找到一个方法: 1.下载flash最新版for chrome : https://fpdownload.macromedia.com/pu ...
- iBatis简单入门教程
iBatis 简介: iBatis 是apache 的一个开源项目,一个O/R Mapping 解决方案,iBatis 最大的特点就是小巧,上手很快.如果不需要太多复杂的功能,iBatis 是能够满足 ...
- 使用Cordova编译Android平台程序提示:Could not reserve enough space for 2097152KB object heap
大体的意思是系统内存不够用,创建VM失败.试了网上好几种方法都不行,最后这个方法可以了: 开始->控制面板->系统->高级设置->环境变量->系统变量 新建变量: 变量名 ...
- XML和JSON数据格式对比
概念 XML 扩展标记语言 (Extensible Markup Language, XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语 ...
- linux查看某个进程内存占用情况以及/proc/pid/status解释
以nginx 为例1.toptop -b -n 1 |grep nginx|awk '{print "VIRT:"$5,"RES:"$6,"cpu:& ...
- 20.谈谈对mvc的认识。
MVC是 模型(Model) .视图(View).控制器(Control) 的英文首字母的缩写,核心思想是:视图和用户交互 通过事件导致控制器改变 控制器改变导致模型改变 或者控制器同时改变两者 模型 ...
- LCD接口(转载)
LCD接口分类 1. I8080接口,我觉得应该就是所谓的8080,通常会用在12864屏上面,且有内部sdram,不需要实时的刷新图片,速度有限制, 支持的数据宽度有8/9/16/18bit,接 ...