Featured Replies
Archivado
Este tema está ahora archivado y está cerrado a más respuestas.
A better way to browse. Learn more.
A full-screen app on your home screen with push notifications, badges and more.
Este tema está ahora archivado y está cerrado a más respuestas.
Hola buenas tardes, mi nombre es Isabel.
Mi Problema es el siguiente: necesito realizar una consulta SQL a una tabla dbf desde una macro en excel, y poner los resultados en una hoja de excel, mi problema es con una consulta que sobrepasa los 255 caracteres ya que ese es el límite de los String, lo intente con variables Variant pero a la hora de pasar los parametros para hacer la consulta en la tabla me lo corta a 255 cáracteres y por consecuencia me marca error de ODBC, para las consultas menores a 255 no tengo ningun problema, abajo agrego el código que uso:
En esta macro tomo la primera parte del select que es lo que varia en mis consultas
[i]En esta otra función tomo la segunda parte del select que es la común para todas mis consultas y mando llamar a la función que hace la conexion a mi tabla .dbf[/i]
Dim celda As String
Dim arr As Variant
arr = Array(arreglo(0), arreglo(1), " var_a = '1'")
celda = columna + "8"
Run (EjecutarParaCelda45(arr, hoja, celda))
arr = Array(arreglo(0), arreglo(1), " var_a = '2'")
celda = columna + "9"
Run (EjecutarParaCelda45(arr, hoja, celda))
arr = Array(arreglo(0), arreglo(1), " var_a = '3'")
celda = columna + "10"
Run (EjecutarParaCelda45(arr, hoja, celda))
End Function[/PHP]
[i]Y en esta última funcion hago la conexión a la tabla, paso la sentencia SQL y [b]el error me lo marca en la parte de rst.Open[/b][/i]
Dim cn As Object
Dim SQL As Variant
Dim i, j, y As Integer
' crea un objeto Connection
Set cn = CreateObject("ADODB.Connection")
' IMPORTANTE: Indicar la cadena de conexión a usar
cn.ConnectionString = "Driver={Microsoft Visual FoxPro Driver};SourceType=DBF;SourceDb=D:\ruta de la tabla\;"
' verifica que los parámetros no estén vacios
If arr(0) <> vbNullString And hoja <> vbNullString Then
' variable para al rec de ado
Dim rst As Object
' abre la conexión a la base de datos
cn.Open
' crea un nuevo objeto recordset
' Nuevo recordset
Set rst = CreateObject("ADODB.Recordset")
SQL = arr(0) + arr(1) + arr(2)
'rst.Open arr(0) & arr(1) & arr(2), cn, adOpenDynamic, adLockOptimistic
'rec.Open arr(0) & arr(1) & arr(2), cn
rst.Open SQL, cn, 1, 3
With rst
If .EOF And .BOF Then
Sheets(hoja).Range(celda).Value = "0"
Else
Sheets(hoja).Range(celda).Value = rst.Fields(0)
End If
End With
' cierra y descarga las referencias
rst.Close
cn.Close
Set cn = Nothing
Set rst = Nothing
End If
End Function[/PHP]
Espero a verme explicado de una buena manera
Gracias de ante mano
SLQ a mas de 255.xls