Linq To Sql进阶系列(二)M:M关系2011-08-20 博客园 Tom Song在Linq To Sql进阶系列(一) 一文中,我们谈到了数据库中的两种基本关系1:M 与1:1. 而现实世 界中,还有一种M:M 的关系。比如,一个老师可以有多个学生,而一个学生也可以有多个老师。老师和 学生的关系就是多对多的关系。这些关系在数据库中是如何反映的呢?在C#3.0入门系列(十)-之Join操作一文中,我们提到了M:M 的关系中的join操作。哦,原来,M:M 的关系在数据库中,依然是通过1:M 来体现。比如,在一个域内,一个User可以加入到多个Group中,一 个Group也可以包含多个User。 User与Group并没有直接的关系,而是通过第三个表UserInGroup发生关 系。User与 UserInGroup的关系为1:M,其关系键为UserId, 而Group与 UserInGroup的关系也为1:M, 其 关系键为GroupId,这样,我们通过第三个表,让User与Group发生了关系,他们的关系为M:M.这三个表的脚本如下:SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO IF NOT EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N"[dbo].[User]") AND OBJECTPROPERTY(id, N"IsUserTable") = 1) BEGIN CREATE TABLE [dbo].[User]( [UserId] [nchar](10) NOT NULL, [UserName] [nchar](10) NULL, CONSTRAINT [PK_User] PRIMARY KEY CLUSTERED ( [UserId] ASC ) ON [PRIMARY] ) ON [PRIMARY] END GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO IF NOT EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N"[dbo].[Group]") AND OBJECTPROPERTY(id, N"IsUserTable") = 1) BEGIN CREATE TABLE [dbo].[Group]( [GroupId] [nchar](10) NOT NULL, [GroupName] [nchar](10) NULL, CONSTRAINT [PK_Group] PRIMARY KEY CLUSTERED ( [GroupId] ASC ) ON [PRIMARY] ) ON [PRIMARY] END GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO IF NOT EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N"[dbo].[UserInGroup]") AND OBJECTPROPERTY(id, N"IsUserTable") = 1) BEGIN CREATE TABLE [dbo].[UserInGroup]( [UserId] [nchar](10) NOT NULL, [GroupId] [nchar](10) NOT NULL, CONSTRAINT [PK_UserInGroup] PRIMARY KEY CLUSTERED ( [UserId] ASC, [GroupId] ASC ) ON [PRIMARY] ) ON [PRIMARY] END GO IF NOT EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N"[dbo]. [FK_UserInGroup_Group]") AND type = "F") ALTER TABLE [dbo].[UserInGroup] WITH CHECK ADD CONSTRAINT [FK_UserInGroup_Group] FOREIGN KEY([GroupId]) REFERENCES [dbo].[Group] ([GroupId]) GO ALTER TABLE [dbo].[UserInGroup] CHECK CONSTRAINT [FK_UserInGroup_Group] GO IF NOT EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N"[dbo]. [FK_UserInGroup_User]") AND type = "F") ALTER TABLE [dbo].[UserInGroup] WITH CHECK ADD CONSTRAINT [FK_UserInGroup_User] FOREIGN KEY([UserId]) REFERENCES [dbo].[User] ([UserId]) GO ALTER TABLE [dbo].[UserInGroup] CHECK CONSTRAINT [FK_UserInGroup_User]