繁体   English   中英

如何使用外部实体链实现NHibernate批量插入实体

[英]How to implement NHibernate batch insert entity with chain of foreign entities

我正在尝试在外键实体链中批量插入一些实体。 实体ID被映射为身份。

我有一个A列表,其中B作为属性,B具有C作为属性。

当我尝试将更改提交到数据库时,它给我一个错误:“对象引用了一个未保存的瞬态实例-在刷新之前保存该瞬态实例,或者将该属性的级联操作设置为可以使其自动保存的值。”

class Program
{
    static viod Main (string[] args)
    {
        var list = new List<A>{
            new A{
                B = new B{
                    C = new C{
                        Name = "test";
                    }
                }
            },
            new A{
                B = new B{
                    C = new C{
                        Name = "test";
                    }
                }
            },
        };

        foreach(var a in list)
        {
            statelessSession.Insert(a);
            //session.Save(a);    // I have tried this as well, does not work neither.
        }
        transaction.Commit();
    }
}

public class A : BaseEntity
{
    public virtual B B{get; set;}
}
public class B : BaseEntity
{
    public virtual C C{get; set;}
}

public class C : BaseEntity
{
    public virtual string Name{get; set;}
}

public class BaseEntity
{
    public virtual long ID {get; set;}
}

你不能

使用身份要求NHibernate选择最后一个插入内容,以使ID与下一条记录相关联。

http://www.philliphaydon.com/2011/09/the-benefits-of-letting-the-orm-generate-the-identity-part-1/

您需要使用Guid Comb或HiLo。

这些使NHibernate可以自己生成密钥并在批处理和插入之前创建所有关联。

暂无
暂无

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

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