0

私は正しいマッピングを探し回っていますが、成功していません。

あきらめた人を見つけ始めましたhttps://groups.google.com/forum/#!topic/fluent-nhibernate/u_MYdOTD1Jk

では、どのようにマッピングしますか

IDictionary<Entity1,Entity2> ?

私が試したことを投稿しますが、今は15回目です..

public class Entity1Map : ClassMap<Entity1>
{
    public Entity1Map()
    {
         Id(x=> x.ID);
    }
}

public class Entity2Map : ClassMap<Entity2>
{
    public Entity2Map()
    {
         Id(x=> x.ID);
    }
}


public class Entity3 { public IDictionary<Entity1,Entity2> Dict { get;set; } }
public class Entity3Map : ClassMap<Entity3>
{
    public Entity3Map()
    {
         Id(x=> x.ID);

         //DictMap??
    }
}

どうもありがとう :)

4

1 に答える 1

0

エンティティマップを使用します。以下は私のために働いています

public class Entity3Map : ClassMap<Entity3>
{
    public Entity3Map()
    {
        Id(x => x.Id);

        HasManyToMany(x => x.Dict)
            .Table("linkTable")
            .Cascade.All()
            .AsEntityMap();
    }
}


var e1 = new Entity1();
var e2 = new Entity2();
using (var tx = session.BeginTransaction())
{
    session.Save(e1);
    session.Save(new Entity3 { Dict = { { e1, e2 } } });
    tx.Commit();
}
session.Clear();

var entity3 = session.Query<Entity3>().FetchMany(x => x.Dict).ToList().First();

Assert.Equal(1, entity3.Dict.Count);
Assert.Equal(e1.Id, entity3.Dict.First().Key.Id);
Assert.Equal(e2.Id, entity3.Dict.First().Value.Id);
于 2013-10-29T10:44:23.067 に答える