📄 namedquerycollectioninitializer.cs
字号:
using log4net;
using NHibernate.Engine;
using NHibernate.Impl;
using NHibernate.Loader.Collection;
namespace NHibernate.Persister.Collection
{
public class NamedQueryCollectionInitializer : ICollectionInitializer
{
private readonly string queryName;
private readonly ICollectionPersister persister;
private static readonly ILog log = LogManager.GetLogger(typeof(NamedQueryCollectionInitializer));
public NamedQueryCollectionInitializer(string queryName, ICollectionPersister persister)
{
this.queryName = queryName;
this.persister = persister;
}
public void Initialize(object key, ISessionImplementor session)
{
if (log.IsDebugEnabled)
{
log.Debug(string.Format("initializing collection: {0} using named query: {1}", persister.Role, queryName));
}
//TODO: is there a more elegant way than downcasting?
AbstractQueryImpl query = (AbstractQueryImpl) session.GetNamedSQLQuery(queryName);
if (query.NamedParameters.Length > 0)
{
query.SetParameter(query.NamedParameters[0], key, persister.KeyType);
}
else
{
query.SetParameter(0, key, persister.KeyType);
}
query.SetCollectionKey(key).SetFlushMode(FlushMode.Never).List();
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -