作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要在 SQL Server 数据库中的两个表之间引入多对多关系,这两个表都有一个整数作为主键。这在 T-SQL 中如何最好地完成?
考虑以下两个示例表定义,它们应该存在多对多关系:
CREATE TABLE [dbo].[Authors] (
[Id] INT IDENTITY (1, 1) NOT NULL,
CONSTRAINT [PK_Versions] PRIMARY KEY CLUSTERED ([Id] ASC)
);
CREATE TABLE [dbo].[Books] (
[Id] INT NOT NULL,
PRIMARY KEY CLUSTERED ([Id] ASC)
);
最佳答案
传统方式是使用额外的 many:many
(junction) 表,它链接到两个表:
CREATE TABLE [dbo].[AuthorsBooks] (
-- Optionally, we can give the table its own surrogate PK
[Id] INT IDENTITY(1,1) NOT NULL,
AuthorId INT NOT NULL,
BookId INT NOT NULL,
-- Referential Integrity
FOREIGN KEY(AuthorId) REFERENCES Authors(Id),
FOREIGN KEY(BookId) REFERENCES Books(Id),
-- PK is either the surrogate ...
PRIMARY KEY CLUSTERED ([Id] ASC)
-- ... Or the compound key
-- PRIMARY KEY CLUSTERED (AuthorId, BookId)
);
AuthorId, BookId
成为主键,或者是否添加您自己的新代理 - 这通常是一种主观偏好。
AuthorId
和 BookId
作为外键)。 Books
的好处。或 Authors
表而无需先加入联结表。 Nationality
是
PersonCountry
的连接表):
-- Find all books written by AuthorId 1234
SELECT b.*
FROM Books b
INNER JOIN AuthorsBooks ab
ON b.Id = ab.BookId
WHERE ab.AuthorId = 1234;
关于sql-server - 如何在 SQL Server 中为多对多关系建模?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13970628/
我是一名优秀的程序员,十分优秀!