NHibernate:保存Object1与列表到数据库

本文关键字:Object2 数据库 列表 保存 Object1 NHibernate | 更新日期: 2023-09-27 18:18:33

我的Nhibernate应用程序有问题。我有一门课叫Rozmiar,还有一门课叫Symbol。符号包含List作为属性

如何使用NHibernate保存到数据库中?

我的代码(不能正常工作):

符号类:

public class Symbol
{
    public virtual int Id { get; set; }
    public virtual string Nazwa { get; set; }
    public virtual bool Sitodruk { get; set; }
    public virtual List<Rozmiar> Rozmiar { get; set; }
    public Symbol() { }
    public Symbol(string nazwa, List<Rozmiar> lista)
    {
        using (ISession sesja = Program.baza.SessionFactory.OpenSession())
        {
            using (ITransaction transaction = sesja.BeginTransaction())
            {
                Symbol s = new Symbol();
                s.Nazwa = nazwa;
                s.Rozmiar = lista;
                sesja.Save(s);
                transaction.Commit();
            }
        }
    }
}

ROZMIAR类:

    public class Rozmiar
    {
        public virtual int Id { get; set; }
        public virtual string Nazwa { get; set; }
        public Rozmiar() { }

        public Rozmiar(string nazwa)
        {
            using (ISession sesja = Program.baza.SessionFactory.OpenSession())
            {
                using (ITransaction transaction = sesja.BeginTransaction())
                {
                    Rozmiar r = new Rozmiar();
                    r.Nazwa = nazwa;
                    sesja.Save(r);
                    transaction.Commit();
                }
            }
        }
}
地图:

public class RozmiarMap : ClassMap<Rozmiar>
{
    public RozmiarMap()
    {
        Table("Rozmiar");
        SchemaAction.All();
        Id(x => x.Id).GeneratedBy.Identity();
        Map(X => X.Nazwa).Not.Nullable();
    }
}
public class SymbolMap : ClassMap<Symbol>
{
    public SymbolMap()
    {
        Table("Symbol");
        SchemaAction.All();
        Id(x => x.Id).GeneratedBy.Identity();
        Map(x => x.Nazwa).Not.Nullable();
        HasMany(x => x.Rozmiar).KeyColumn("IdRozmiar");
    }
}

和生成示例对象的方法:

public static void Generuj()
        {
            List<Rozmiar> listA = new List<Rozmiar>();
            listA.Add(new Rozmiar("750 mm"));
            listA.Add(new Rozmiar("900 mm"));
            listA.Add(new Rozmiar("1050 mm"));
            listA.Add(new Rozmiar("1200 mm"));
            Symbol a1 = new Symbol("A-1", listA);
            Symbol a2 = new Symbol("A-2", listA);
            Symbol a3 = new Symbol("A-3", listA);
        }

在调试模式下,我看到,listA包含4个对象,但这些对象的属性为Id = 0和Nazwa = null:(也许有一个主要问题…

我也不知道我的映射设置是否正确。

顺便说一句。连接设置和配置是ok的,因为我在这段代码中有其他类,它正确地保存到数据库中。

NHibernate:保存Object1与列表<Object2>到数据库

在带有string参数的Rozmiar的构造函数中,您正在创建Rozmiar的不同(new)实例。因此,当您添加到由

创建的listA实例时
new Rozmiar("750 mm")

持久化是不同的对象

Rozmiar r = new Rozmiar();

另外,将您的映射从List<Rozmiar>更改为IList<Rozmiar>。请看这里:6.1。持久集合支持的集合映射接口的完整列表