当前位置: 代码迷 >> .NET Framework >> Entity Framework可以模型跟数据库不一致吗
  详细解决方案

Entity Framework可以模型跟数据库不一致吗

热度:167   发布时间:2016-05-01 23:25:36.0
Entity Framework可以模型和数据库不一致吗?
经常会有以下场景:
数据库设计中,A表和B表,没有设计物理上的外键关联,但是在逻辑上却有A表的A1字段和B表的B2字段存在一对多的关联情况。
那在EF中,可以采用设计模型和物理数据库不一致的方式进行吗?也就是在EF模型中手动添加一个A1和B2的关联。
如果可以,该如何做呢?
才用EF不久,不太清楚,暂时用的是DB First模式。Oracle数据库。
------解决思路----------------------
参考: Entity Framework 手动 添加 关联 - 备忘
------解决思路----------------------
最好不要修改ef自动生成的model,我记得之前我在处理关联表实体类时,都是先分析哪个是主表,然后自己建一个实体类,继承自主表的实体类,在这个子类中写上你要的副表字段。这样在使用ef查询时,用select投影出一个子类的实例,就可以达到不必要的表连接
------解决思路----------------------
EF和数据表不会不一致,两者本来就是相互映射的关系
------解决思路----------------------
另建一个实体,只是用来显示关联数据用的。
然后用EF,join查询关联两表,并转换成新的实体。
  相关解决方案