在静态类内使用连接字符串时引发空引用异常

时间:2018-07-08 18:59:01

标签: c# asp.net-mvc-5 connection-string static-classes

在我的项目中,我在非静态类中使用了连接字符串,并且工作正常。但是现在我正在开发一个在静态类中使用连接字符串的项目。在Catch块下面的代码中,将引发错误,如下所示:

  

NullReferenceException:对象引用未设置为对象的实例。

如果我将“ Throw”这一行注释掉,则可以正常工作,但是我想了解代码中出了什么问题。

DataAccess类:

public class DataAccess
{
    static string connstr =  ConfigurationManager.ConnectionStrings["DbSystem2018"].ConnectionString;

    public static object GetSingleAnswer(string sql, List<SqlParameter> PList)
    {
        object obj = null;

        SqlConnection conn = new SqlConnection(connstr);

        try
        {
            conn.Open();
            SqlCommand cmd = new SqlCommand(sql, conn);

            if (PList != null)
            {
                foreach (SqlParameter p in PList)
                    cmd.Parameters.Add(p);
            }

            obj = cmd.ExecuteScalar();
        }
        catch (Exception ex)
        {
            throw; // THIS LINE THROW THE NullReferenceException Error
        }
        finally
        {
            conn.Close();
        }

        return obj;
    }
}

问题在于在静态类中使用静态连接字符串字段。因此,有什么方法可以在不使用任何非静态公共类的情况下解决此问题?

已更新:

请注意以下几点:

  1. 我不想使用非静态方法,我的问题是如何使用静态方法解决此问题。

  2. 使用静态字段时,我们会立即对其进行初始化:

    static string v1 = "hello";
    

    但是,为什么以下代码的初始化在返回实际的连接字符串之前抛出null?

    static string connstr = ConfigurationManager.ConnectionStrings["DbSystem2018"].ConnectionString;
    

顺便说一句,web.config内部的连接字符串很好。

1 个答案:

答案 0 :(得分:3)

此:

System.Configuration.Configuration config = System.Web.Configuration.WebConfigurationManager.OpenWebConfiguration(null);
if (config.ConnectionStrings.ConnectionStrings.Count > 0)
{
    var connString = config.ConnectionStrings.ConnectionStrings[nameOfConnectionString].ToString();
    return connString;
}

是从以下位置复制粘贴:https://www.codeproject.com/Articles/1012286/Read-web-config-Settings

问题是您正在访问配置文件。必须先将这些对象转换为对象,然后才能使用它们。这就是上面的代码。