我正在使用带有 SQL Express 2005 的 .net 4.0 Framework (VB)。我需要在使用 datareader 嵌套时使用 do。就像是.......
SQLQuery1="Select * from Table1"
cmd = New Data.SqlClient.SqlCommand(SQLQuery1, myConn)
If cmd.Connection.State = 1 Then cmd.Connection.Close()
cmd.Connection.Open()
dr = cmd.ExecuteReader
Do While dr.Read
SQLQuery2="Select * from Table2 where ID=" & dr.item("field1")
cmd2 = New Data.SqlClient.SqlCommand(SQLQuery2, myConn)
If cmd2.Connection.State = 1 Then cmd2.Connection.Close()
cmd2.Connection.Open()
dr2 = cmd2.ExecuteReader
Do While dr2.Read
--------- Execute Insert/Update Statement here ----------------
loop
dr2.close
loop
dr.close
它第一次执行,但是当它第二次返回“Do While dr.Read”时,它给出错误 Invalid attempt to call Read when reader is closed。 我在连接字符串中使用 MARS=true 但没有看到任何区别。
我在哪里做错了?
谢谢