连接表(二)

本文详细介绍了SQL Server中的三种特殊连接类型:交叉连接、自连接和全外连接。交叉连接返回两个表的笛卡尔积,自连接用于查询同一表中的相关行,而全外连接则在左右两表中返回所有行,即使没有匹配项。通过实例和图表,阐述了每种连接的用法和效果,并提供了具体的SQL查询示例。
摘要由CSDN通过智能技术生成

 SQL Server 交叉连接

CROSS JOIN 连接两个或多个不相关的表。

以下是两个表的SQL Server CROSS JOIN 的语法:

SELECT

select_list

FROM T1

CROSS JOIN T2;

或者

SELECT

select_list

FROM T1, T2;

CROSS JOIN 将第一个表(T1)中的每一行与第二个表(T2)中的每一行连接起来。 换句话说,交叉连接返回两个表中行的笛卡尔积

与INNER JOIN或LEFT JOIN不同,交叉连接不会在连接的表之间建立关系。

假设 T1 表包含三行: 1 , 2 和 3 , T2 表包含三行: A , B 和 C 。

CROSS JOIN 从第一个表(T1)获取一行,然后为第二个表(T2)中的每一行创建一个新行。 然后它对第一个表(T1)中的下一行执行相同操作,依此类推。

在此图中, CROSS JOIN 总共创建了 9 行。 通常,如果第一个表有 n 行,第二个表有 m 行,则交叉连接将产生 n x m 行。

SQL Server自连接

自联接用于将表连接到自身(同一个表)。 它对于查询分层数据或比较同一个表中的行很有用。

自联接使用内连接或左连接子句。 由于使用自联接的查询引用同一个表,因此表别名用于为查询中的表分配不同的名称。

请注意,如果在不使用表别名的情况下在查询中多次引用同一个表,则会出现错误。

以下是将表 T 连接到自身的语法:

SELECT

select_list

FROM T t1

[INNER | LEFT] JOIN T t2 ON

join_predicate; 

上面查询语句中两次引用表 T 。表别名 t1 和 t2 用于为 T 表分配不同的名称。

staffs 表存储员工信息,如身份证,名字,姓氏和电子邮件。 它还有一个名为 manager_id 的列,用于指定直接管理者。

例如,员工 Mireya 向管理员者 Fabiola 汇报工作,因为 Mireya 的 manager_id 列中的值是

Fabiola 。

Fabiola 没有经理,因为它的 manager_id 列是一个 NULL 值。

要获取工作汇报关系,请使用自联接,如以下查询中所示:

SELECT

e.first_name + ' ' + e.last_name employee,

m.first_name + ' ' + m.last_name manager

FROM

sales.staffs e

INNER JOIN sales.staffs m ON m.staff_id = e.manager_id

ORDER BY

manager;

在这个例子中,两次引用了 staffs 表:一个是员工的 e ,另一个是管理者的 m 。

连接谓词使用 e.manager_id 和 m.staff_id 列中的值匹配 employee 和 manager 关系。

由于 INNER JOIN 效应, employee 列没有 Fabiola Jackson 。 如果用 LEFT JOIN 子句替换 INNER JOIN 子句,

SQL Server全外链接

FULL OUTER JOIN当左表或右表中存在匹配项时,该命令将返回所有行。

下面创建一些示例表来演示全外连接。

首先,创建一个名为 pm 的新模式,它代表项目管理。 

CREATE SCHEMA pm;

GO

接下来,在 pm 模式中创建名为 projects 和 members 的新表:

CREATE TABLE pm.projects(

id INT PRIMARY KEY IDENTITY,

title VARCHAR(255) NOT NULL

);

CREATE TABLE pm.members(

id INT PRIMARY KEY IDENTITY,

name VARCHAR(120) NOT NULL,

project_id INT,

FOREIGN KEY (project_id)

REFERENCES pm.projects(id)

);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值