我试图在不加载更新值的情况下进行快速更新查询 我试图使用此代码
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();
}
}
但是我收到错误播放器在实际映射时没有映射,我已经在另一个语句中使用它了。
答案 0 :(得分:1)
我猜您的实体名称是Player
而不是播放器 s 对吗?
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
对象。