LINQ to SQL映射关系概述

开发 后端
这里介绍LINQ to SQL映射关系,LINQ to SQL 定义了 AssociationAttribute 属性来帮助表示此类关系。此属性与 EntitySet 和 EntityRef 类型一起使用,来表示将作为数据库中的外键关系的内容。

LINQ to SQL有很多值得学习的地方,这里我们主要介绍LINQ to SQL映射关系,包括介绍LINQ to SQL映射关系Demo等方面。

LINQ to SQL映射关系

在 LINQ to SQL 中,数据库关联(如外键到主键关系)是通过应用 AssociationAttribute 属性表示的。

可以在您的实体类中将始终相同的任何数据关系编码为属性引用。例如,在 Northwind 示例数据库中,由于客户通常会下订单,因此在模型中客户与其订单之间始终存在关系。

LINQ to SQL 定义了 AssociationAttribute 属性来帮助表示此类关系。此属性与 EntitySet 和 EntityRef 类型一起使用,来表示将作为数据库中的外键关系的内容。
◆EntitySet :为 LINQ to SQL 应用程序中的一对多关系和一对一关系的集合方提供延迟加载和关系维护。
◆EntityRef:为 LINQ to SQL 应用程序中的一对多关系的单一实例方提供延迟加载和关系维护。

大多数关系都是一对多关系,这一点在本主题后面部分的示例中会有所体现。您还可以按如下方式来表示一对一和多对多关系:

◆一对一:通过向双方添加 EntitySet<(Of <(TEntity>)>) 来表示此类关系。

例如,假设有一个 Customer-SecurityCode 关系,创建此关系的目的是使得在 Customer 表中找不到客户的安全码,而只有得到授权的人才能访问此安全码。

◆多对多:在多对多关系中,链接表(也称作联接表)的主键通常由来自其他两个表的外键组合而成。

例如,假设有一个通过使用链接表 EmployeeProject 构成的 Employee-Project 多对多关系。LINQ to SQL 要求使用以下三个类对这种关系进行模型化: Employee、Project 和 EmployeeProject。在这种情况下,更改 Employee 和 Project 之间的关系似乎需要更新主键 EmployeeProject。但是,这种情况***的模型化处理方法是删除现有 EmployeeProject,然后创建新的 EmployeeProject。

LINQ to SQL映射关系Demo

  1. [Table(Name = "Student")]  
  2. public class Student  
  3. {  
  4. [Column(IsPrimaryKey = true)]  
  5. public int ID;  
  6. [Column]  
  7. public string StuName;  
  8. [Column]  
  9. public bool Sex;  
  10. [Column]  
  11. public int Age;  
  12. private EntitySet _Scores;  
  13. [Association(Storage = "_Score"OtherKey = "StudentID")]  
  14. public EntitySet Scores  
  15. {  
  16. get { return this._Scores; }  
  17. set { this._Scores.Assign(value); }  
  18. }  
  19. }  
  20. [Table(Name = "Score")]  
  21. public class Score  
  22. {  
  23. [Column(IsPrimaryKey = true)]  
  24. public int ID;  
  25. [Column]  
  26. public int StudentID;  
  27. [Column]  
  28. public float Math;  
  29. [Column]  
  30. public float Chinese;  
  31. [Column]  
  32. public float English;  
  33. [Column]  
  34. public DateTime Times;  

【编辑推荐】

  1. Linq匿名委托类型
  2. Linq异常处理详细介绍
  3. Linq Setting字段描述
  4. Linq数据和对象浅谈
  5. Linq内部执行原理剖析
责任编辑:佚名 来源: 51CTO.com
相关推荐

2009-09-09 16:07:16

Linq实体关系

2009-09-11 12:13:40

LINQ to SQL

2009-09-18 16:12:22

LINQ TO SQL

2009-09-15 13:37:24

Linq To Sql

2009-09-17 16:46:34

Linq to sql

2009-09-15 13:53:53

Linq To Sql

2009-09-15 11:14:33

LINQ to SQL

2009-09-15 13:14:01

LINQ to SQL

2009-09-10 13:42:47

Linq UserIn

2009-09-10 11:10:21

Linq Librar

2009-09-18 16:07:10

Linq Where操

2009-09-08 16:08:44

Linq使用order

2009-09-08 11:25:42

Linq foreac

2009-09-18 16:20:36

LINQ基础

2009-09-18 13:44:38

LINQ设计模式

2009-09-16 17:21:53

LINQ遍历

2009-09-14 15:15:45

LINQ技术

2009-09-10 16:28:17

LINQ查询

2009-09-14 09:55:55

Linq基本语法

2009-09-17 11:35:40

Linq匿名类型
点赞
收藏

51CTO技术栈公众号