首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无加载的Fluent-NHibernate查询

无加载的Fluent-NHibernate查询
EN

Stack Overflow用户
提问于 2013-10-16 07:20:08
回答 1查看 703关注 0票数 1

我试图在不加载更新值的情况下执行快速更新查询,我尝试使用以下代码

代码语言:javascript
复制
 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();
            }
        }

但是我得到错误播放器没有映射,而它实际上是映射的,我已经在另一个语句中使用了它。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-10-16 07:27:16

我想你的实体名是Player而不是Player,对吗?

代码语言:javascript
复制
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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19397382

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档