gpt4 book ai didi

c# - Nhibernate 数据库连接时空引用异常

转载 作者:太空宇宙 更新时间:2023-11-03 18:45:13 24 4
gpt4 key购买 nike

当我的程序开始连接到 Windows XP 上的 MS SQL 2005 EXPRESS DB 时,有时会出现此异常。有时我会收到此错误,有时不会... NHibernate v3

DBMonitor 类在单独的线程上运行,但只能在一个线程上运行, future 可以在多个线程上运行。

我有类似的 SessionProviderMsSql2005 类,但仅用于 SQLite 连接,它具有相同的问题,并且 sqlite 的 session 提供程序在多个线程上运行...

System.NullReferenceException: Object reference not set to an instance of an object.
at System.Collections.Generic.Dictionary`2.Insert(TKey key, TValue value, Boolean add)
at System.Collections.Generic.Dictionary`2.set_Item(TKey key, TValue value)
at NHibernate.Impl.SessionFactoryObjectFactory.AddInstance(String uid, String name, ISessionFactory instance, IDictionary`2 properties)
at NHibernate.Impl.SessionFactoryImpl..ctor(Configuration cfg, IMapping mapping, Settings settings, EventListeners listeners)
at NHibernate.Cfg.Configuration.BuildSessionFactory()
at MySolution.DatabaseLayer.Repositories.SessionProviderMsSql2005.get_SessionFactory()
at MySolution.DatabaseLayer.Repositories.SessionProviderMsSql2005.OpenSession()

有我的 SessionProviderMsSql2005 类

using System;
using System.Collections.Generic;
using NHibernate;
using NHibernate.Cfg;
using Environment = NHibernate.Cfg.Environment;

namespace MySolution.DatabaseLayer.Repositories
{
public class SessionProviderMsSql2005
{
private static readonly object _padlock = new object();

private static Configuration _configuration;
public static Configuration Configuration
{
get
{
lock (_padlock)//must be thread save!
{
if (_configuration == null)
{

if (string.IsNullOrEmpty(InitialCatalog))
{
throw new NullReferenceException("Property InitialCatalog could not be null or empty!");
}

if (string.IsNullOrEmpty(ServerName))
{
throw new NullReferenceException("Property ServerName could not be null or empty!");
}

_configuration = new Configuration();
_configuration.Configure("Config/Hibernate.MsSql2005.cfg.xml");
_configuration.AddAssembly("MySolution.DatabaseLayer");
Configuration.AddProperties(new Dictionary<string, string>
{
{ Environment.ConnectionString, @"Server="+ServerName+";initial catalog="+InitialCatalog+";Integrated Security=SSPI;" }
});
}
return _configuration;
}
}
}

private static ISessionFactory _sessionFactory;
public static ISessionFactory SessionFactory
{
get
{
lock (_padlock)
{
if (_sessionFactory == null)
{
lock (_padlock)
{
_sessionFactory = Configuration.BuildSessionFactory();
}
}
return _sessionFactory;
}
}
}

public static string ServerName { get; set; }
public static string InitialCatalog { get; set; }


private SessionProviderMsSql2005()
{ }

public static ISession OpenSession()
{
lock (_padlock)
{
return SessionFactory.OpenSession();
}
}

public static void CloseSession()
{
lock (_padlock)
{
SessionFactory.Close();
}
}
}
}

我是这样使用这个类的:

 public class DBMonitor
{
private ISession _session;


public DBMonitor(string serverName, string initialCatalog)
{
SessionProviderMsSql2005.ServerName = serverName;
SessionProviderMsSql2005.InitialCatalog = initialCatalog;
}

public void Start()
{

_session = SessionProviderMsSql2005.OpenSession();

IList data = _session.CreateSQLQuery("SELECT * FROM someTable WHERE id = 1").List();

...
}
}

知道是什么原因造成的吗?

更新:更正 SessionFactory getter。是否正确?

最佳答案

这可能是一个多线程问题,与 NHibernate 没有直接关系,请在此处查看相同的问题和答案:Throw a NullReferenceException while calling the set_item method of a Dictionary object in a multi-threding scenario

关于c# - Nhibernate 数据库连接时空引用异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4942905/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com