这里有个坑,我们定义实体的时候如果使用了在数据库没有的字段记得加[NotMapped]---------每一个遇到的坑总结后都是一比财富。
在项目中我们一般会使用EF等ORM框架来为我们服务,在ORM中一般已经为我们定义好了相关的字段和数据库的映射关系。但是我们一定要记得为在数据库中没有的字段设置[NoMapped]这个不需要映射的属性。如下实例:
public class Student
{
public string Id{get;set;}
public string Name{get;set;}
public List<Classes> classes{get;set;}
}
public class Classes
{
public string ClassId{get;set;}
}
这样的写法,但是在我们定义ORM的上下文的时候,我们经常把Student和Classes一起放到同一个上下文中去查询,这个写法在编译的时候是不会有问题的,但是当我们正式执行的时候会发现我们在上下文中查询第二个实例的时候,系统报错为数据库链接已断开。无法链接的错误,造成这样的原因是因为List<Classes>实际上在我们数据库并没有映射造成的。因此我们定义实体的时候记得在所以没有映射关系的字段上加上[NoMapped]。同时加上引用
using System.ComponentModel.DataAnnotations.Schema;
原文:http://www.cnblogs.com/zuimengaitianya/p/5060594.html