[英]insert an array into mysql using vb.net vs vba
我已经将所有数据从Internet检索到二维数组中,我知道如何使用vba记录集以及如何使用循环过滤和更新。 以下是vba代码的一部分。
困难的问题在这里:
Using cmd As New MySqlCommand("INSERT INTO `calls` (`CID`, `ctype`) VALUES (@CID, @ctype)", cnn)
这使我无法使用数组中的任何循环进行相应的更新。
cmd.Parameters.Add ('@CID').value = arrValue(i,j)
我希望可以通过以下方式完成此操作:
for x = 0 to ubound(arrValue,0)
for y = 0 to ubound(arrValue,1)
.fields(arrHeader(y) = arrValue(x,y)
next y
next x
说我,要更新的第n个,j =标头的值
vba提取物:
With rs
'Worksheets(strWsName).Activate
'iLastRow = Worksheets(strWsName).Cells(65535, 1).End(xlUp).row 'column B, column 2
For i = 0 To UBound(arrValue, 1)
Debug.Print "Updating " & i + 1 & " of " & UBound(arrValue, 1) + 1 & " news ..." ' of " & strCodeAB & " ..."
'Start looping the news row
strNewsID = arrValue(i, 1) 'Worksheets(strWsName).Range(ColRefNewsID & i).Value
If strNewsID = "" Then
Debug.Print i - 1 & " news is updated to database"
i = UBound(arrValue, 1)
Else
strFilter = "fID='" & strNewsID & "'"
rs.Filter = strFilter
If rs.EOF Then
.AddNew 'create a new record
'add values to each field in the record
For j = 0 To UBound(arrTitle_ALL)
'20140814
strFieldValue = .Fields(arrAccessField(j))
strNewValue = arrValue(i, j)
If IsNull(strFieldValue) And strNewValue = "" Then
Else
.Fields(arrAccessField(j)) = arrValue(i, j) 'Worksheets(strWsName).Cells(i, j + 1).Value
End If
Next j
On Error Resume Next '***************
.Update 'stores the new record
On Error GoTo 0
iCounterNewsAdded = iCounterNewsAdded + 1
glcounterNewsAdded = iCounterNewsAdded
Else
以下帖子似乎与我的要求类似,但我不知道该怎么做。 [参考] 使用“ IN”命令传递数组作为要在SQL查询中使用的参数
您提到的帖子(使用IN()命令)可在WHERE子句中使用,但对值无效。 MySQL无法传递数组,因此您需要遍历数组并运行多个INSERT语句:
for y = 0 to ubound(arrValue,1)
cmd.Parameters.AddWithValue(@CID,arrValue(0,y))
cmd.Parameters.AddWithValue(@ctype,arrValue(1,y))
cmd.ExecuteNonQuery
next y
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.