我试图从一个包含多个实体之间的多对多关系数据的类中获得一些重用。
您可以很容易地做到这一点,其中关系只是使用 Map 的两个实体的 pk
class A{
icollection<Item> Items
}
class B{
icollection<Item> Items
}
class Item{
string Text
}
然后在配置中你做这样的事情
Entity<A>().HasMany(e=>e.Items).WithMany().Map(..);
Entity<B>().HasMany(e=>e.Items).WithMany().Map(..);
这将为 A 和 B 生成一个新的链接表
现在,我想在链接表上存储更多信息,但这很常见
class A{
icollection<LinkItem> Items
}
class B{
icollection<LinkItem> Items
}
class LinkItem{
int ExtraInfo
Item Text
}
class Item{
string Text
}
这失败了,因为 LinkItem 是在单个表中创建的并且抱怨关系
“‘DataContext.LinkItem’中的实体参与‘A_Items’关系。找到了0个相关的‘A_Items_Source’。预计有1个‘A_Items_Keywords_Source’。”
您可以在 Map 方法中指定一个表,m.ToTable("AItems"),但这也失败了
“在模型中找不到指定的表'AItems'。确保已正确指定表名。”
我可以以某种方式重用我的 LinkItem 类吗?
(它不需要从 DataContext 中作为一个集合访问)