由于EF的这个小怪癖,我有一个令人沮丧的情况.这是一个简单的行为演示.首先是数据库架构:
如您所见,RestrictedProduct是产品的一个特例,我打算用一些特殊的代码创建Product的子类.
现在我导入到EF数据模型:
哎呀! EF看到RestrictedProduct只有两个字段,都是FK,所以它将它映射为Product和Restriction之间的一对多关系.所以我回到数据库并向RestrictedProduct添加一个Dummy字段,现在我的EF模型看起来好多了:
但那个Dummy领域是愚蠢而毫无意义的.也许我可以删除它?我从数据库表和实体模型中删除了该字段,然后从数据库刷新模型…
不好了!产品限制关联以新名称(RestrictedProduct1)返回!另外,它不会编译:
Error 3034: Problem in mapping fragments starting at lines (x,y) :Two entities with possibly different keys are mapped to the same row. Ensure these two mapping fragments map both ends of the AssociationSet to the corresponding columns.
有没有办法防止这种行为,没有在RestrictedProduct表上保留Dummy字段?
解决方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。