一、Entity的注解属性(Annotations)
不管是code first还是db first,都需要用到注解属性,至于用System.ComponentModel.DataAnnotations命名空间提供的,还是EntityFramework程序集提供的,现在来做个总结。
(EntityFramework程序集using不进来,不知道什么原因,暂时先总结System.ComponentModel.DataAnnotations命名空间的)
1、System.ComponentModel.DataAnnotations
DataAnnotation 特性由.NET 3.5中引进,给.NET中的类提供了一种添加验证的方式。常用的Annotation有:
Key
Required
MaxLength/MinLength
NotMapped
ComplexType
ConcurrencyCheck
Timestamp
Table
Column
DatabaseGenerated
ForeignKey
InverseProperty
2、EntityFramework
System.ComponentModel.DataAnnotations命名空间中只定义了部分实体验证的特性,在EntityFramework程序集中定义了更多的数据映射特性。
参考:
http://www.cnblogs.com/guomingfeng/archive/2013/06/12/mvc-ef-configuration-migration.html
http://www.cnblogs.com/panchunting/p/entity-framework-data-annotations.html
http://www.cnblogs.com/aehyok/p/3328253.html
二、Code First默认多重关系的一些约定规则
1、一对多关系
关于外键列名默认约定,在《Programming Entity Framework Code First》一书中,给出的3种外键列名的约定方式是:
[Target Type Key Name]
[Target Type Name] + [Target Type Key Name]
[Navigation Property Name] + [Target Type Key Name]
对应的中文翻译为:
[目标类型的键名]
[目标类型名称]+[目标类型键名称]
[引用属性名称]+[目标类型键名称]
举例说明:
比如有两个类Category和Product,要使得Category与Product之间具有一对多关系,Entity Framework Code First可以有3种体现方式:
(1)、在Category类中定义ICollection<Product> Products集合属性,同时在Product类中定义CategoryID引用属性。
(2)、仅在Category类中定义ICollection<Product> Products集合属性。
(3)、仅在Product类中定义Category Category引用属性(定义一个Category类型的字段)。
备注:
Code First在根据定义的类生成数据表时,数据表之间的外键关系及所生成的外键列名有默认的约定。但这种约定同样可以进行修改的,
修改方法就是使用Data Annotations或Fluent API。
2、多对多关系
Code First在根据定义的多对多关系的类生成数据表时,除了生成实体类定义的属性表之外,还会生成一个中间表,用于体现两个实体表之间的多对多的关系。
3、一对一关系
使用Data Annotations或Fluent API设置。
如:
[Key]
[ForeignKey("User")]
public int ProfileID { get; set; }
内容来源:
http://www.cnblogs.com/libingql/p/3353112.html