NHibernate:插入后需要用@@ identity更新对象ID

时间:2009-05-28 15:20:05

标签: c# asp.net-mvc nhibernate

我第一次使用NHibernate并且苦苦挣扎。在第一页上,我开始一个表格。我想保存并导航到第二页。如何使用新插入的行的ID更新RequestForm对象?当我调用重定向时它仍然是0,尽管数据被持久保存到数据库。

这是我的控制器代码:

    [AcceptVerbs(HttpVerbs.Post)]
    public ActionResult New(RequestForm form)
    {
        // contract
        if (form == null)
        {
            throw new ArgumentException("Cannot be null", "form");
        }

        // validate the form
        form.Validate(ModelState);

        // if valid, save & continue
        if (ModelState.IsValid)
        {
            var request = new Request();
            form.Update(request);
            repository.Save(request);
            return RedirectToAction("Edit", "Request", new {id = form.ID});
        }

        // if not valid, return new form
        return View("New", form);
    }

以下是存储库代码:

    public void Save(T entity)
    {
        using (ISession session = GetSession())
        using (ITransaction transaction = session.BeginTransaction())
        {
            session.SaveOrUpdate(entity);
            transaction.Commit();
        }
    }

这是映射文件的相关区域:

<class
  name="Request"
  table="Data_Requests"
  dynamic-update="true">

<id 
  name="Id" 
  type="Int32" 
  access="property"
  column="RequestId"
  unsaved-value="0">
  <generator class="native"/>
</id>

感谢您阅读我的问题。一旦你知道自己在做什么,我肯定答案很简单:)

2 个答案:

答案 0 :(得分:0)

您是否尝试过设置<generator class="identity"/>。它应该适用于本地人,但谁知道......

答案 1 :(得分:0)

好的 - 愚蠢的错误

return RedirectToAction("Edit", "Request", new {id = form.ID});

应该是

return RedirectToAction("Edit", "Request", new {id = request.ID});