sql >> Base de Datos >  >> RDS >> PostgreSQL

Usando ADO en VBA para conectarse a PostgreSQL

No quiero usar un DSN porque estoy usando un controlador ODBC en lugar de OLE DB. Al hacer referencia a un DSN, el código anterior funciona con muy pocos cambios.

Consulte esta pregunta para saber cómo encontré la respuesta una vez que comencé a sospechar que OLE DB/ODBC estaba relacionado con el problema. work-with-odbc-drivers-or-only-ole-db-providers">¿ADO funciona con controladores ODBC o solo con proveedores OLE DB?

Código nuevo aquí:

Sub GetCustomers()
Dim oConn As New ADODB.connection
Dim cmd As New ADODB.Command
' Connection Parameters
Dim strUsername As String
Dim strPassword As String
Dim strServerAddress As String
Dim strDatabase As String
' User:
strUsername = Sheets("CONFIG").Range("B4").Value
' Password:
strPassword = Sheets("CONFIG").Range("B5").Value
' Server Address:
strServerAddress = Sheets("CONFIG").Range("B6").Value
' Database
strDatabase = Sheets("CONFIG").Range("B3").Value


oConn.Open "DSN=my_system_dsn;" & _
    "Database=" & strDatabase & ";" & _
    "Uid=" & strUsername & ";" & _
    "Pwd=" & strPassword

Set xlSheet = Sheets("CUSTOMERS")
xlSheet.Activate
Range("A3").Activate
Selection.CurrentRegion.Select
Selection.ClearContents
Range("A1").Select

Dim strSQL As String
strSQL = "SELECT * FROM customers"

cmd.CommandType = ADODB.CommandTypeEnum.adCmdText
cmd.ActiveConnection = oConn
cmd.CommandText = strSQL

Set rs = New ADODB.Recordset
Set rs = cmd.Execute

For i = 1 To rs.Fields.Count
    ActiveSheet.Cells(3, i).Value = rs.Fields(i - 1).Name
Next i

xlSheet.Range(xlSheet.Cells(3, 1), _
    xlSheet.Cells(3, rs.Fields.Count)).Font.Bold = True

ActiveSheet.Range("A4").CopyFromRecordset rs

xlSheet.Select
Range("A3").Select
Selection.CurrentRegion.Select
Selection.Columns.AutoFit
Range("A1").Select

rs.Close
oConn.Close

Set cmd = Nothing
Set param = Nothing
Set rs = Nothing
Set cnn = Nothing
Set xlSheet = Nothing
End Sub

El DSN del sistema está configurado para usar el controlador PostgreSQL Unicode. Elegí no usar OLE DB a pesar de que hay un proveedor disponible. Si observa PGFoundry, verá que tiene muchos problemas y no se ha actualizado en varios años.