SQL Server 连接两张表的实例:从零开始

1. 前言

SQL Server 是一个广泛使用的关系型数据库管理系统,它可以很好地操作和管理数据,还提供了许多强大的功能。在数据库中,表是最基本的数据组织形式,而在实际的项目中,我们通常需要对多个表进行操作和处理。本文将从零开始,介绍如何连接 SQL Server 中的两张表,并附加实例代码。

2. SQL Server 连接两张表

2.1 INNER JOIN 连接

在 SQL Server 中,INNER JOIN 是最常用的两张表连接方式,它可以将两张表中符合条件的数据连接在一起。

例如,我们有两张表:表 A 和表 B。它们分别包含不同的字段。现在,我们要根据 A 表中的某个字段和 B 表中的某个字段进行连接,可以使用以下代码:

SELECT A.field1, A.field2, B.field1, B.field2

FROM A

INNER JOIN B

ON A.field1 = B.field2;

其中,SELECT 表示要查询的字段,FROM 表示要查询的表。INNER JOIN 和 ON 则表示要连接的表和条件。在代码中,我们根据 A 表中的 field1 字段和 B 表中的 field2 字段进行连接。

这个查询语句将返回 A 表和 B 表中符合条件的数据。这里需要注意的是,所连接的两张表中必须至少有一个字段是相同的,否则无法进行连接。

2.2 LEFT JOIN 连接

除了 INNER JOIN,SQL Server 还提供了 LEFT JOIN 连接。LEFT JOIN 连接可以返回左表中的所有数据以及右表中符合条件的数据。

例如,我们有两张表:表 A 和表 B。现在,我们要查询 A 表中的所有数据以及 B 表中与 A 表相关的数据,可以使用以下代码:

SELECT A.field1, A.field2, B.field1, B.field2

FROM A

LEFT JOIN B

ON A.field1 = B.field2;

其中,SELECT、FROM 和 ON 的含义与 INNER JOIN 中相同。LEFT JOIN 增加了一个“LEFT”,表示要查询左表中的所有数据。右表中没有与左表符合条件的数据时,相应的字段将返回 NULL。

3. 实例:两张表的连接

在本节中,我们将通过一个实例,演示如何连接 SQL Server 中的两张表。

在该实例中,我们有两张表:Goods 和 Orders。Goods 表包含各种商品的信息,而 Orders 表包含某些商品的订单信息。我们要根据它们之间的商品 ID 字段进行连接,查询出每个商品的订单信息。

首先,我们需要创建这两张表以及相应的数据。由于篇幅限制,这里不再赘述。代码如下:

CREATE TABLE Goods

(

GID INT PRIMARY KEY,

GName VARCHAR(20),

Price DECIMAL(10, 2),

Manufacturer VARCHAR(20)

)

CREATE TABLE Orders

(

OID INT PRIMARY KEY,

GID INT,

Qty INT,

OrderTime DATETIME,

FOREIGN KEY (GID) REFERENCES Goods(GID)

)

INSERT INTO Goods VALUES (1, 'iPhone', 10000.00, 'Apple')

INSERT INTO Goods VALUES (2, 'Galaxy', 8000.00, 'Samsung')

INSERT INTO Goods VALUES (3, 'Mi 9', 3500.00, 'Xiaomi')

INSERT INTO Orders VALUES (1, 1, 10, '2021-07-04 08:00:00')

INSERT INTO Orders VALUES (2, 3, 50, '2021-07-06 10:00:00')

在数据创建成功后,我们可以使用以下代码,查询每个商品的订单信息:

SELECT *

FROM Goods

LEFT JOIN Orders

ON Goods.GID = Orders.GID;

这个查询语句将返回 Goods 表中所有的数据以及 Orders 表中符合条件的数据。对于没有订单信息的商品,相应的字段将返回 NULL。

除此之外,我们还可以根据需要,选择要查询的字段,例如:

SELECT GName, Price, Qty, OrderTime

FROM Goods

LEFT JOIN Orders

ON Goods.GID = Orders.GID;

这个查询语句将返回每个商品的名称、价格以及订单数量和订单时间。

4. 总结

SQL Server 连接两张表是数据库中的常见操作。在本文中,我们介绍了 SQL Server 中两种常见的连接方式:INNER JOIN 和 LEFT JOIN,并通过一个实例,演示了如何连接两张表。希望本文能够对读者理解 SQL Server 数据库的表连接操作有所帮助。

数据库标签