data:image/s3,"s3://crabby-images/0cf23/0cf238e0871846f35316324dffd0e1dbd0a70590" alt=""
How to update an Access Table using ADO
The following code snippet would be helpful to update an Access 2007 database table using VBA. The code uses ADO and requires a reference to ActiveX Data Objects Library
The sample uses a simple table which contains a name and a location field.
data:image/s3,"s3://crabby-images/28929/289293c207cac1d79d7354389ddd9100f0442be7" alt=""
The code uses the SQL update query to update the database. The query is executed by the ADO’s command execute method
Sub Simple_SQL_Update_Data()
Dim Cn As ADODB.Connection '* Connection String
Dim oCm As ADODB.Command '* Command Object
Dim sName As String
Dim sLocation As String
Dim iRecAffected As Integer
On Error GoTo ADO_ERROR
Set Cn = New ADODB.Connection
Cn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\Users\comp\Documents\SampleDB.accdb;Persist Security Info=False"
Cn.ConnectionTimeout = 40
Cn.Open
sName = "Krishna Vepakomma"
sLocation = "Cincinnati, OH"
Set oCm = New ADODB.Command
oCm.ActiveConnection = Cn
oCm.CommandText = "Update SampleTable Set Location ='" & sLocation & "' where UserName='" & sName & "'"
oCm.Execute iRecAffected
If iRecAffected = 0 Then
MsgBox "No records inserted"
End If
If Cn.State <> adStateClosed Then
Cn.Close
End If
Application.StatusBar = False
If Not oCm Is Nothing Then Set oCm = Nothing
If Not Cn Is Nothing Then Set Cn = Nothing
ADO_ERROR:
If Err <> 0 Then
Debug.Assert Err = 0
MsgBox Err.Description
Err.Clear
Resume Next
End If
End Sub
data:image/s3,"s3://crabby-images/a7b07/a7b07d83454209f3605d1132f9b0f94f8559c989" alt=""
Table Before Update Command
data:image/s3,"s3://crabby-images/1b658/1b6585b84bb0e38853ba79cf5154452e9e216bad" alt=""
Table After Update Command