1

我正在尝试在不加载更新值的情况下进行快速更新查询我尝试使用此代码

 public void Save(int PlayerID, string Column, object Value)
        {
            using (ISession session = new SessionManager(_connectionString).Open())
            {
                IQuery query = session.CreateQuery("UPDATE Players SET " + Column + "= :newValue WHERE PlayerID=:PlayerID");
                query.SetParameter("newValue", Column);
                query.SetParameter("PlayerID", PlayerID);
                query.ExecuteUpdate();
            }
        }

但我得到错误 Player is not mapped while its actual mapped and I already used it in another statements。

4

1 回答 1

1

我猜你的实体名称是Player而不是玩家对吗?

IQuery query = session.CreateQuery("UPDATE Player SET " + Column + "= :newValue WHERE PlayerID=:PlayerID");
            query.SetParameter("newValue", Column);
            query.SetParameter("PlayerID", PlayerID);
            query.ExecuteUpdate();

您不必在 hql 中指定表的名称,只需指定实体的名称即可。

除此之外,您可以使用代理,只需使用session.Load(...)为给定的 id 加载代理对象。这不会命中数据库。但是您可以使用session.Delete对象的代理。

在此处查看更多详细信息:http: //nhibernate.info/blog/2009/04/29/nhibernate-the-difference-between-get-load-and-querying-by-id.html

于 2013-10-16T07:27:16.487 回答