繁体   English   中英

将域实体映射到多个表

[英]Mapping a domain entity to multiple tables

我有一个定义这样的对象(过滤器)

public class Filter
{
    public int FilterId { get; set; }

        public string Name { get; set; }

        public IList<User> Users { get; set; }
}

如果可能的话,我想将对象存储在多个表中(有时跨多个行)

给定过滤器的初始化是这样的:

Filter myFilter = new Filter();
myFilter.FilterId = 1;
myFilter.Name = "Name of my filter";
myFilter.Users.Add(new User("Joe", 10));
myFilter.Users.Add(new User("Jim", 20));

..我希望将其保留在表“ Filter”和“ Filter_User”中

过滤器最终将具有:

1我的过滤器名称

Filter_User将包含

1 10(参考乔的ID)1 20(参考吉姆的ID)

我一直在查看文档,而我所能找到的就是在映射文件中使用元素。 但据我所知,它只能让我使用组件关系(即Employee和EmployeeDetails-1:1)来做到这一点

有人给我指出正确的方向吗?

我认为您只是在寻找多对多关联? 您不受组件关系的约束。

您可以看一下多对多映射类型吗?

<set name="Users" table="Filter_User">
  <key column="filterid" />
  <many-to-many column="userid" class="User" />
</set>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM