【发布时间】:2011-03-18 09:34:29
【问题描述】:
我有以下代码:
Imports System.Data
Imports System.Data.OleDb
Partial Class Dummy
Inherits System.Web.UI.Page
Dim r As OleDbDataReader
Dim con As OleDb.OleDbConnection
Dim cmd As OleDbCommand
Dim cmd1 As OleDbCommand
Dim prev_ob As New List(Of Int64)
Dim cur_ob As Integer
Dim i As Integer = 0
Protected Sub Button1_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button1.Click
con = New OleDb.OleDbConnection("provider=SQLOLEDB;data source=PC;initial catalog=DB1;integrated security=SSPI")
cmd = New OleDbCommand("select single_column from table1 where date_reqd=(SELECT CONVERT(VARCHAR(10),DATEADD(DD, DATEDIFF(DD, 0, GETDATE()), -1),120))", con)
con.Open()
r = cmd.ExecuteReader
While r.Read
prev_ob.Add(Val(r.Item(0)))
End While
cmd = New OleDbCommand("select column1, column2, date_reqd from table1 where date_reqd=(select CONVERT(varchar(10), GETDATE(),120))", con)
r = cmd.ExecuteReader
While r.Read
For i As Integer = 0 To prev_ob.Count - 1
cur_ob = Val(prev_ob(i)) + Val(r.Item(0))
cmd1 = New OleDbCommand("update table1 set column4='" & cur_ob & "' where column2='" & r.Item(1) & "' and date_reqd='" & r.Item(2) & "'", con)
cmd1.ExecuteNonQuery()
i += 1
Exit For
Next
End While
con.Close()
End Sub
End Class
我面临的问题是更新仅针对许多值中的第一个正确发生。所有其他值都是计算出来的,因此在我的表中更新不正确。我几乎可以肯定循环是导致问题的原因,但一直无法找到解决方法。请帮我改正。
【问题讨论】:
-
你是在不检查任何条件的情况下调用 Exit For 吗?
-
@vs 开发者:你好! :) Exit For 只是我试图使该死的事情起作用的众多变体之一。不幸的是,我删除了所有其他变体,只是粘贴了我所拥有的。我也试过
For Each,For Each obj in prev_ob等等等等。没用。在那种情况下,发生的事情是它用最后一个计算值更新了所有行的值。当我输入MsgBox时,它显示了正确的值。我去数据库看看,它已经插入了最后一个计算值。 WTF错了吗? : -
看起来这应该可以作为单个 UPDATE 语句(column1 和 single_column 是同一列吗?)
标签: vb.net for-loop while-loop sqldatareader sql-update