📄 namedqueryloader.cs
字号:
using log4net;
using NHibernate.Engine;
using NHibernate.Impl;
using NHibernate.Loader.Entity;
namespace NHibernate.Persister.Entity
{
/// <summary>
/// Not really a <tt>Loader</tt>, just a wrapper around a named query.
/// </summary>
public class NamedQueryLoader : IUniqueEntityLoader
{
private readonly string queryName;
private readonly IEntityPersister persister;
private static readonly ILog log = LogManager.GetLogger(typeof(NamedQueryLoader));
public NamedQueryLoader(string queryName, IEntityPersister persister)
{
this.queryName = queryName;
this.persister = persister;
}
public object Load(object id, object optionalObject, ISessionImplementor session)
{
if (log.IsDebugEnabled)
{
log.Debug(string.Format("loading entity: {0} using named query: {1}", persister.EntityName, queryName));
}
AbstractQueryImpl query = (AbstractQueryImpl) session.GetNamedQuery(queryName);
if (query.HasNamedParameters)
{
query.SetParameter(query.NamedParameters[0], id, persister.IdentifierType);
}
else
{
query.SetParameter(0, id, persister.IdentifierType);
}
query.SetOptionalId(id);
query.SetOptionalEntityName(persister.EntityName);
query.SetOptionalObject(optionalObject);
query.SetFlushMode(FlushMode.Never);
query.List();
// now look up the object we are really interested in!
// (this lets us correctly handle proxies and multi-row
// or multi-column queries)
return session.PersistenceContext.GetEntity(new EntityKey(id, persister, session.EntityMode));
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -