【问题标题】:The ConnectionString property has not been initialized. VB.NetConnectionString 属性尚未初始化。 VB.Net
【发布时间】:2016-04-20 19:11:45
【问题描述】:

我有以下代码:

            Dim command As New SqlCommand

        command.Parameters.AddWithValue("@customerid", textbox1.text)
        command.Parameters.AddWithValue("@password", textbox2.text)

        command .Connection = SharedVar.ConnectionString
        SharedVar.ConnectionString.Open()
        command .CommandText = ("SELECT Customer FROM Accounts WHERE CustomerID = @customerid AND Password = @password")

当我执行代码时,我在这个位置得到一个错误:

SharedVar.ConnectionString.Open()

我收到的错误是:ConnectionString 属性尚未初始化。

SharedVar 是一个模块,在这个模块中有一个名为 ConnectionString 的变量。 ConnectionString 被声明为 SQLConnection。连接字符串本身保存在 application.settings 中。 SharedVar.ConnectionString 的代码是:

    Public ConnectionString As New SqlConnection(My.Settings.ConnectionString)

我不确定为什么会收到此错误,因为我已经在以下位置声明了 ConnectionString 属性:

command .Connection = SharedVar.ConnectionString

My.Settings.ConnectionString 中保存的连接字符串为:

Data Source=(LocalDB)\MSSQLLocalDB;AttachDbFilename=C:\Users\Nico\Documents\Visual Studio 2015\Database\CustomerDatabase.mdf;Integrated Security=True

感谢您的帮助。

【问题讨论】:

  • 我认为至少就变量命名而言,您的连接与连接字符串混淆了。

标签: sql vb.net connection-string


【解决方案1】:

您可能需要重新评估变量命名,因为这可能会有些混乱。您当前的代码将实际的SqlConnection 对象实例化为ConnectionString(而不仅仅是连接字符串本身,它是String):

' This creates an actual connection. (My.Settings.ConnectionString is '
' your connnection string) '                                           
Public ConnectionString As New SqlConnection(My.Settings.ConnectionString)

在构建查询时考虑使用如下模式:

' Build your connection '
Using connection As New SqlConnection(My.Settings.ConnectionString)
    ' Create your query '
    Dim query = "SELECT Customer FROM Accounts WHERE CustomerID = @customerid AND Password = @password"
    ' Build a command to execute '
    Using command As New SqlCommand(query, connection)
         ' Open your connection '
         connection.Open()
         ' Add your parameters ' 
         command.Parameters.AddWithValue("@customerid", textbox1.Text)
         command.Parameters.AddWithValue("@password", textbox2.Text)
         ' Execute your query into a reader '
         Using reader = command.ExecuteReader()
               While reader.Read()
                    ' Access your custom information here '
                    Dim customer = reader("Customer")
                    ' Do something else here ... '
               End While
         End Using
    End Using
End Using

此外,如果不查看整个 sn-p 代码,就很难准确判断您的某些属性何时设置。这可能只是连接字符串的一个实例,只是在调用 Open() 方法之前没有在 Connection 上设置。

【讨论】:

  • 感谢您的详细回答。我尝试使用您的代码,但仍然显示相同的错误。此外,在上面显示的代码之前,我没有更多代码。我做了更多调查并尝试了这个: textbox1.Text = My.Settings.ConnectionString 但即使在我手动输入连接字符串的程序的 My.Settings 中,textbox1.text 也是空的。这一定是问题,但我不知道如何解决它。谢谢。
  • 您的连接字符串是否存储在您的app.config 文件中?
  • 是的,我的连接字符串存储在我的项目文件夹中名为 app.config 的文件中
  • 你试过用System.Configuration.ConfigurationManager.ConnectionStrings("{your-connection-string-name}").ConnectionString阅读它吗?
  • 我该怎么做? :/ 我尝试使用您的代码,但我收到 ConfigurationManager 不是 System.Configuration 成员的错误消息。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-10-13
  • 1970-01-01
相关资源
最近更新 更多