一、连接条件

  连接查询中用来连接连个表的条件称为连接条件或连接谓词。其形式为:

[<表1>].<列名1> <连接运算符> [<表2>].<列2>  

  常见的连接运算符包括

  1、比较运算符:=、>、<、>=、<=、!=、between和and。

  2、逻辑运算符:not、and、or。

  3、使用between和and连接查询形式为[<表1>].<列名1><between>[<表2>].<列名2>and[<表2>].<列名3>。

二、连接按照结果集分类

  1、内连接:表中的行互相连接。结果集的行数等于每个表满足条件的行数的乘积,参与连接的表示平等的。

  2、外连接:参与连接的表有主次之分,主表的每一行数据去匹配从表的数据列,符合连接条件的数据将直接返回到结果集中,不符合连接条件的数据列将以null填充后返回到结果集中,其中外连接又分左外连接、右外连接和全连接3种。

  [1] 等值连接查询

select p.*,c.*
from country as c,person as p
where c.countryid = p.countryid

  上面的等值连接中,两张表都有countryid字段,因此查出来的结果中就会有两列countryid

  [2] 在等值结果中消除数据就是自然连接

select p.name,c.countryname from country as c,person as p where c.countryid = p.countryid

  [3] 自身连接

  一个数据表自己与自己建立连接称为自身连接

、内连接

  1、内连接查询的语法结构如下:

SELECT <属性或表达式列表>
FROM <表名> [INNER] JOIN <表名>
ON <连接条件>
[ WHERE <限定条件> ]

  INNER 可以省略,只有 JOIN 时就是省略了inner。内连接就是传统的连接操作,这里用 ON 子句指定连接条件,用 WHERE 子句指定连接后的其他限定条件:

select p.name,c.countryname
from country as c inner join person p on p.countryid = c.countryid

、左外连接查询

  1、左外连接查询的语法结构,OUTER 可省略:

SELECT <属性或表达式列表>
FROM <表名> LEFT [OUTER] JOIN <表名>
ON <连接条件>
[ WHERE <限定条件> ]

  如下:

SELECT TA.RoleId,TA.RoleName,TB.FunctionCode
FROM SysRole TA LEFT JOIN SysRoleFunction TB ON TA.RoleId = TB.RoleId

  注意:

  [1] 第一个表为主表,第二个表为从表;

  [2] 在查询结果集中包含第一个表中满足条件的所有记录,如果第二个表存在ON子句连接条件匹配的记录,则第二个表返回相应值,否则第二个表返回null。也就是说,不管第二个表有没有记录匹配,第一个表的所有字段都会返回,这就是外连接与内连接的区别。

  

五、右外连接查询

  1、右外连接查询的语法结构如下:

SELECT <属性或表达式列表>
FROM <表名> RIGHT OUTER JOIN <表名>
ON <连接条件>
[ WHERE <限定条件> ]

  2、实例:

SELECT TB.RoleId,TB.FunctionCode,TA.RoleName
FROM SysRole TA RIGHT JOIN SysRoleFunction TB ON TA.RoleId = TB.RoleId

  注:

  [1] 第一个表为从表,第二个表为主表;

  [2] 在查询结果集中包含第二个表中满足条件的所有记录,如果第一个表存在ON子句连接条件匹配的记录,则第一个表返回相应值,否则第一个表返回null。也就是说,不管第一个表有没有记录匹配,第二个表的所有字段都会返回。

  

六、全外连接查询

  1、全外连接查询的语法结构如下:

SELECT <属性或表达式列表>
FROM <表名> FULL [ OUTER ] JOIN <表名>
ON <连接条件>
[ WHERE <限定条件>]

  注:

  [1] 两个表同为主表;

  [2] 在查询结果集中包含两个表中的所有记录,如果存在ON子句连接条件匹配的记录,则另一个表返回相应值,否则另一个表返回null。也就是说,不管表记录有没有记录匹配,两个表的所有字段都会返回。

七、交叉连接

  交叉连接Corss join,用于将第一张表的所有记录与第二张表的所有记录组合一次并返回。

    执行如下SQL语句:

SELECT LastName + firstname 
FROM name2 CROSS JOIN name1

  

八、联合查询union(union all)

   union是一个特殊的运算符,用于将两个或两个以上的查询产生一个结果集。join将信息水平连接(添加更多列),而union将信息垂直连接(添加更多行)。

   当使用union处理查询时,要注意以下几个关键点。

   (1)、所有union的查询必须在select列表中有相同的列数。即如果第一个查询有3个列数,第二个查询也要只有3个列数。

   (2)、union返回结果的标题集仅从第一个查询中获得,无论第二个查询如何命名或取别名都不会更改。

   (3)、查询中对应的列的数据类型必须隐式一致。注意不要求完全一致,只需要隐式一致。

   (4)、与其他非union不同,union的默认返回选项为distinct,而不是all。union all语句与union的不同点仅仅在于遇到相同的记录,会全部保留。

SQL语法 之 表连接的更多相关文章

  1. SQL的多表连接查询

    SQL的多表连接查询 多表连接查询具有两种规范,SQL92和SQL99规范. SQL92规范支持下列多表连接查询: (1)等值连接: (2)非等值连接: (3)外连接: (4)广义笛卡尔积: SQL9 ...

  2. 章节2:SQL之多表连接

    原文:章节2:SQL之多表连接 Sql的多表连接关系有:内连接.外连接和交叉连接. 先建立两个用于演示的表: TB_Characters: Id Character 1 内向 2 外向 3 中性性格 ...

  3. SQL语句多表连接查询语法

    一.外连接 1.左连接  left join 或 left outer join SQL语句:select * from student left join score on student.Num= ...

  4. sql之多表连接

    最近遇到特别多多表连接的问题,因此随笔记下,开始学java和mysql的时间太短,有见解不周的地方,希望读者可以提出探讨. 对于left join.right join和inner join(join ...

  5. sql数据库的表连接方式图文详解

    sql数据库表连接,主要分为:内连接.外连接(左连接.右连接 .全连接).交叉连接,今天统一整合一下,看看他们的区别.   首先建表填充值. 学生表:student(id,姓名,年龄,性别 ) 成绩表 ...

  6. SQL update 多表连接方法

    SQL Update多表联合更新的方法 () sqlite 多表更新方法 //---------------------------------- update t1 set col1=t2.col1 ...

  7. SQL server 数据库——表连接(多表横向连接,纵向连接)

    表连接 1.select * from student,score --笛卡尔积 2.两个表的连接: 法1:select student.sno, sname, degree from student ...

  8. sql语句左右表连接理解

    一句话,左连接where只影响坐标,右连接where只影响右表

  9. 【HCIA Gauss】学习汇总-数据库管理(SQL语法 库表 索引操作)-5

    # 简单查询select * from table_reference # 创建表 create table TB(staff_id int primary key , course_name cha ...

随机推荐

  1. [webpack] devtool里的7种SourceMap[转]

    modle: development cheap-source-map debug 不太方便,不是以原来的文件的形式cheap-module-source-map 可以 debugcheap-modu ...

  2. 【HDU 6017】 Girls Love 233 (DP)

    Girls Love 233 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)To ...

  3. Properties Editor 中文编辑器 汉化

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 在Eclipse的 [Help]-> [ Install New Software ...

  4. 又见Python<2>:如何安装第三方库(Windows)

    使用python进行数据分析或者数据处理时,往往需要使用一些库,而使用库之前必须安装它.Anaconda内置了很多常用的第三方库,可以满足绝大部分需求,比如numpy.pandas.matplotli ...

  5. Codeforces 372 B. Counting Rectangles is Fun

    $ >Codeforces \space 372 B.  Counting Rectangles is Fun<$ 题目大意 : 给出一个 \(n \times m\) 的 \(01\) ...

  6. [BZOJ4817][SDOI2017]树点涂色(LCT+DFS序线段树)

    4817: [Sdoi2017]树点涂色 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 692  Solved: 408[Submit][Status ...

  7. editplus运行php 配置

    工具->配置用户工具->添加工具:Menu Text 改成runphp或者其他任名称.Command 安装的php.exe的地址.如D:\ wamp\php\php5.4.3\php.ex ...

  8. 注解@Aspect实现AOP功能

    springboot中pom引入jar <!-- aop 切面 --> <dependency> <groupId>org.springframework.boot ...

  9. LCA POJ 1330 Nearest Common Ancestors

    POJ 1330 Nearest Common Ancestors Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 24209 ...

  10. [转]Android中的android:layout_width和android:width

      android:width 其实是定义控件上面的文本(TextView) 的宽度,当然这个宽度也是和 android:layout_width 配合起来作用的,如果 android:layout_ ...