SQL Server知识点三

9、列和表别名

  1. SQL 别名用于为 表 或 表中的列 提供临时名称。
  2. SQL 别名通常用于使 表名 或 列名 更具可读性。
  3. SQL 一个别名只存在于查询期间。

别名使用 AS 关键字,通常可以省略。

建议在下列情况下使用别名

  1. 查询涉及多个表
  2. 用于查询函数
  3. 需要把两个或更多的列放在一起
  4. 列名长或可读性差 

10、连接表

在关系数据库中,数据分布在多个逻辑表中。 要获得完整有意义的数据集,需要使用连接来查询这些表中的数据。

SQL Server支持多种连接,包括 [内连接],[左连接],[右连接],[全外连接]和[交叉连接]。

每种连接类型指定SQL Server如何使用一个表中的数据来选择另一个表中的行。

(1) SQL Server内连接

内连接是SQL Server中最常用的连接之一。 内部联接子句用于查询来自两个或多个相关表的数据。

SQL Server INNER JOIN 子句的语法:

SELECT select_list FROM T1

INNER JOIN T2 ON join_predicate;

(2) SQL Server左连接

LEFT JOIN 子句用于查询来自多个表的数据。

它返回左表中的所有行和右表中的匹配行。

如果在右表中找不到匹配的行,则使用 NULL 代替显示。

(3)ON与WHERE子句

注:对于 INNER JOIN 子句,如果将 ON 子句中的条件放在 WHERE 子句中,则它在功能上是等效的

(4)SQL Server右连接

RIGHT JOIN 子句组合来自两个或多个表的数据。 RIGHT JOIN 开始从右表中选择数据并与左表中的行匹配。 RIGHT JOIN 返回一个结果集,该结果集包含右表中的所有行,无论是否具有左表中的匹配行。 如果左表没有匹配,则结果为NULL。

(5)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 行。

(6)SQL Server自连接

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

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

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

SELECT select_list FROMT t1 [INNER | LEFT] JOIN T t2 ON join_predicate;

(7)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) );

假设每个成员只能参与一个项目,每个项目都有零个或多个成员。 如果项目处于构思阶段,则不会分配任何成员。

然后,向 projects 和 member 表中插入一些行记录:

INSERT INTO pm.projects(title) VALUES('New CRM for Project Sales'), ('ERP Implementation'), ('Develop Mobile Sales Platform');

INSERT INTO pm.members(name, project_id)

VALUES('John Doe', 1), ('Lily Bush', 1), ('Jane Doe', 2), ('Jack Daniel', null);

之后,查询 projects 和 member 表中的数据:

SELECT * FROM pm.projects;

SELECT * FROM pm.members;

最后,使用 FULL OUTER JOIN 查询 projects 和 member 表中的数据:

SELECT m.name member, p.title project FROM pm.members m

FULL OUTER JOIN pm.projects p ON p.id = m.project_id;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值