• 连接表(二)


     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)

    );

  • 相关阅读:
    一文了解常用的微波传输线(一)
    Java OA系统任务协作模块
    03.02-适配器模式(Adapter)
    leetcode:438. 找到字符串中所有字母异位词
    二叉树进阶
    [Linux] CentOS 7图形化界面——安装配置
    LabVIEW基于机器视觉的钢轨表面缺陷检测系统
    Visual Studio 2019 VS编译ffmpeg4.4为静态库或动态库
    [附源码]Python计算机毕业设计Django的疫苗接种管理系统
    我国有多少个港口?
  • 原文地址:https://blog.csdn.net/weixin_47300323/article/details/126220589