Я пишу макрос, по которому хочу удалить несколько имен в столбце A листа 2 из таблицы сервера, называемой login.Удаление записей таблицы mysql с использованием макроса
Имя базы данных «my_db», а имя таблицы - это логин. Я вызываю соединение для подключения к серверной базе данных. Ниже приведен полный код: -
Dim cnt As ADODB.Connection
Dim rst As ADODB.Recordset
Dim Sql As String
Sub Button1_Click()
Dim Ws As Worksheet
Dim Var As String
Dim i As Integer
i = 1
Set Ws = Worksheets("Sheet2")
Var = "login"
Sql = "name"
Call Connection
Do
Sql = " Delete From " & " " & Var & "" & " Where name" = "Ws.Cells(i, 1)"
Call Connection
i = i + 1
Loop Until Ws.Cells(i, 1) = ""
MsgBox "All entries deleted from login table"
End Sub
Dim strUserName As String
Dim strPassword As String
Dim ConnectString As String
Set cnt = New ADODB.Connection
strServerName = "localhost"
strDatabaseName = "my_db"
strUserName = "root"
strPassword = "root1"
ConnectString = "DRIVER={MySQL ODBC 5.1 Driver};" & _
"SERVER=" & strServerName & _
";DATABASE=" & strDatabaseName & ";" & _
"USER=" & strUserName & _
";PASSWORD=" & strPassword & _
";OPTION=3;"
With cnt
.CursorLocation = adUseClient
.Open ConnectString
.CommandTimeout = 0
Set rst = .Execute(Sql)
End With
'rst.Close
'cnt.Close
Set rst = Nothing
Set cnt = Nothing
End Sub
Но записи не удаляются. В синтаксисе SQL есть ошибка, может ли кто-нибудь помочь мне с синтаксисом sql?
Красивый код. И в чем ваш вопрос? –
Я не получаю никаких ошибок, но записи в таблице не удаляются. Вы хотите, чтобы я опубликовал сообщение? –
Да, что вызывает соединение? И куда вы отправляете запрос? –