クラスで2番目のクエリを呼び出すときに、セッションが閉じられる理由がわかりません。
まず、メソッド getPoliceData() を呼び出します。問題なく動作します。その後、GetSkadeData() を呼び出すと、エラーがスローされます。
DbFactory クラスは次のようになります
class DbFactory
{
private static Lazy<ISessionFactory> factory = new Lazy<ISessionFactory>(GetSessionFactory, System.Threading.LazyThreadSafetyMode.ExecutionAndPublication);
public DbFactory()
{
}
public List<PoliceData> getPoliceData() {
using (ISession session = OpenSession())
{
IList<PoliceData> pols = session.Query<PoliceData>().Where(p => p.policyNumber == 053126703).ToList();
return pols.ToList();
}
}
public List<SkadeData> getSkadeData()
{
using (ISession session = OpenSession())
{
IList<SkadeData> skader = session.Query<SkadeData>().Where(p => p.Postnr == "7700").ToList();
return skader.ToList();
}
}
private static ISession OpenSession()
{
return factory.Value.GetCurrentSession();
}
private static ISessionFactory GetSessionFactory()
{
//NHibernate.Cfg.Configuration
var c = new Configuration();
//c.Configure();
c.DataBaseIntegration(db =>
{
db.ConnectionString = "Server=\"localhost\";database=testdb;Integrated Security=SSPI";
db.Dialect<NHibernate.Dialect.MsSql2012Dialect>();
});
//c.Configure("c:\XML.xml");
ModelMapper maps = new ModelMapper();
maps.AddMapping<PoliceDataMap>();
maps.AddMapping<SkadeDataMap>();
c.AddMapping(maps.CompileMappingForAllExplicitlyAddedEntities());
c.CurrentSessionContext<NHibernate.Context.ThreadLocalSessionContext>();
//c.Configure().Configure();
var sessionFac = c.BuildSessionFactory();
return sessionFac;
//return sessionFac.GetCurrentSession();
}
}
別のクラスからメソッドを呼び出すとき、私はこれをやっています
List<PoliceData> test = new List<PoliceData>();
List<SkadeData> skader = new List<SkadeData>();
DbFactory poli = new DbFactory();
test = poli.getPoliceData();
skader = poli.getSkadeData();
dbfactory の新しいインスタンスを作成する必要がありますか、それとも 2 つの異なるクエリに対して同じセッションを使用することは可能ですか? Nhibernate が 1 回確認された後、必要に応じてセッションを開いたり閉じたりするだけでよいと思います。