【发布时间】:2015-01-26 02:16:00
【问题描述】:
我被这个问题难住了,我的数据库是本地主机,所有其他形式我都没有问题,但是在这里,当我单击更新按钮时,我收到这个错误,这非常令人沮丧,因为我非常确定 SQL 连接应该开放!给出了我的按钮代码。
错误:“阅读器关闭时读取尝试无效”
Private Sub UpdateButton_Click(sender As Object, e As EventArgs) Handles UpdateButton.Click
MysqlConn = New MySqlConnection
MysqlConn.ConnectionString = "server=localhost;userid=root;password=alpine;database=database1"
Dim Reader As MySqlDataReader
Dim vals(2, 2) As Decimal
vals(0, 2) = Convert.ToDecimal(Cbudget.Text.ToString - OutBox.Text.ToString + InBox.Text.ToString)
vals(1, 0) = Convert.ToDecimal(Newfigbox.Text.ToString)
vals(2, 0) = Convert.ToDecimal(OutBox.Text.ToString - InBox.Text.ToString)
vals(1, 1) = Convert.ToDecimal(FigureBox.Text.ToString + Newfigbox.Text.ToString)
Try
MysqlConn.Open()
Dim Query As String
Query = "UPDATE accounts SET Current_Budget='" & vals(1, 0) & "';"
Command = New MySqlCommand(Query, MysqlConn)
Reader = Command.ExecuteReader
MysqlConn.Close()
Catch ex As MySqlException
MessageBox.Show(ex.Message)
MysqlConn.Close()
End Try
Try
MysqlConn.Open()
Dim Query As String
Query = "UPDATE stocktable, clientdetails SET stocktable.Quantity='" & vals(1, 1) & "', clientdetails.Balance='" & vals(2, 0) & "' WHERE 'stocktable.Type_Of_Metal' ='" & ComboBox1.Text & "' AND 'clientdetails.Name' ='" & ClientBox.Text & "';"
Command = New MySqlCommand(Query, MysqlConn)
Reader = Command.ExecuteReader
MysqlConn.Close()
Catch ex As MySqlException
MessageBox.Show(ex.Message)
MysqlConn.Close()
End Try
Cbudget.Text = Nothing
Try
MysqlConn.Open()
Dim Query As String
Query = "SELECT Current_Budget FROM accounts"
Command = New MySqlCommand(Query, MysqlConn)
Reader = Command.ExecuteReader
MysqlConn.Close()
While Reader.Read
vals(0, 1) = Reader.GetDecimal("Current_Budget")
Cbudget.Text = vals(0, 1)
End While
MysqlConn.Close()
Catch ex As MySqlException
MessageBox.Show(ex.Message)
MysqlConn.Close()
End Try
End Sub'
【问题讨论】:
-
可能是复制粘贴错误。在您的最后一个查询中,您在阅读之前关闭了连接。删除那个关闭。