NHibernate Fluent将String属性映射到另一个表的列

时间:2014-12-01 18:24:05

标签: c# nhibernate fluent-nhibernate

我在数据库中有一个表,仅用于保存一些ID的描述:

TABLE SomeClass
- Columns
- ClassTypeID INT CONSTRAINT etc

TABLE SomeClassTypes
- ClassTypeID INT IDENTITY
- Description NVARCHAR

它是这样完成的,因此用户可以轻松插入/删除新类型。 我想获得所有SomeClass的报告,但是我希望有一个字符串属性来保存其他表中的描述:

public class SomeClass
{
    public virtual int SomeClassID { get; set; }
    public virtual int ClassTypeID { get; set; }
    public virtual string DescriptionType { get; set; }
}

public class SomeClassMap : ClassMapping<SomeClass>
{
    public SomeClassMap()
    {
        Table("SomeClassTable");
        Property(p => p.SomeClassID, map => 
        { 
            map.Column("SomeClassID");
            map.Generator(Generators.Identity);
        });
        Property(p => p.ClassTypeID, map => map.Column("ClassTypeID"));
        //Other properties here

        Property(p => p.DescriptionType, ?); //This line
    }
}

我该怎么做?

1 个答案:

答案 0 :(得分:0)

尝试使用连接表。

public class SomeClassMap : ClassMapping<SomeClass>
{
public SomeClassMap()
{
    Table("SomeClassTable");
    Property(p => p.SomeClassID, map => 
    { 
        map.Column("SomeClassID");
        map.Generator(Generators.Identity);
    });
    Property(p => p.ClassTypeID, map => map.Column("ClassTypeID"));
    //Other properties here

    Join("SomeClassTypes", m => 
        {
            m.KeyColumn("ClassTypeId");
            m.Fetch.Join();
            m.Map(x => x.DescriptionType).Column("Description");
        })
}
}

<强> EDITED

如果你使用NHibernate内置的流畅映射,试试这个:

public class SomeClassMap : ClassMapping<SomeClass>
{
    public SomeClassMap()
    {
        Table("SomeClassTable");
        Property(p => p.SomeClassID, map => 
        { 
            map.Column("SomeClassID");
            map.Generator(Generators.Identity);
        });
        Property(p => p.ClassTypeID, map => map.Column("ClassTypeID"));
        //Other properties here

        Property(p => p.DescriptionType, ?); //This line
        Join("SomeClassTypes", m => 
            {
                m.Key(k => k.Column("ClassTypeId"));
                m.Fetch(FetchKind.Join);
                m.Property(x => x.DescriptionType).Column("Description");
            });
    }
}