Saltar al contenido

Select de mas de 255 caracteres


Recommended Posts

publicado

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

  Dim columna As String
Dim arr As Variant
Dim celda As String
Dim hoja As String


Sub consultas()
arr = Array("select sum(var1) from tabla1 as a join tabla2 as b on a.var1 = b.var1 and (var_3>0 OR var_4>0 OR var_5>0 or var_6>0 or var_7>0 or var_8>0 or var_9>0 or var_10>0 or var_11>0 or var_12>0 or var_13>0 or var_14>0 or", " var_15>0 or var_16>0 or var_17>0 or var_18>0 or var_19>0 and ")
columna = "c"
hoja = "45"

Run (EjecutarParaColumnaB(arr, hoja, columna))
End Sub[/PHP]

[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]

[PHP]Public Function EjecutarParaColumnaB(arreglo As Variant, hoja As String, columna As String)
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]

[PHP]Public Function EjecutarParaCelda45(arr As Variant, hoja As String, celda As String)


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

publicado

En SQL Server se resuelve con un comando Exec(Sql), pero de FoxPro ni idea.

Se me ocurre que pases completas la Tabla1 y Tabla2 a dos hojas distintas de Excel y realices el Sum y el Join con VBA.

Si no lo tienes claro, sube un archivo con un Select * de ambas tablas y miraré de realizarlo.

Si las tablas son demasiado grandes, sube una muestra de unos 200 registros para poder probar.

publicado

Gracias Macro Antonio, lo que he hecho en otras ocaciones es que desde FOX agrego un campo a las tablas y le pongo una marca a aquellos registros que cumplan con la condición y despues por ese campo los filtro en excel, pero como no es la primera vez que me enfrento a esto ni la última, intento ver si hay algunamanera de hacer la consulta directa a la tabla desde Excel.

Archivado

Este tema está ahora archivado y está cerrado a más respuestas.

  • 109 ¿Te parecen útiles los tips de las funciones? (ver tema completo)

    1. 1. ¿Te parecen útiles los tips de las funciones?


      • No
      • Ni me he fijado en ellos

  • Ayúdanos a mejorar la comunidad

    • Donaciones recibidas este mes: 0.00 EUR
      Objetivo: 130.00 EUR
  • Archivos

  • Estadísticas de descargas

    • Archivos
      188
    • Comentarios
      98
    • Revisiones
      29

    Más información sobre "Cambios en el Control Horario"
    Última descarga
    Por pegones1

    3    1

  • Crear macros Excel

  • Mensajes

    • Saludos amigos espero estén bien  En la actualidad utilizo la siguiente macro para generar un código alfanumérico continuo que al guardar los datos se copia en la Celdas “B5” de las Hojas 58 (MATRIZ1) y Hojas59 (MATRIZ2) Private Sub CommandButton3_Click()     If Hoja58.Range("B5").Value < 9999 Then Hoja58.Range("B5").Value Hoja58.Range("B6").Value + 1     Else        Hoja58.Range("B5").Value = 1     End If If Hoja59.Range("B5").Value < 9999 Then Hoja59.Range("B5").Value = Hoja59.Range("B6").Value + 1 Else        Hoja59.Range("B5").Value = 1     End If End Sub El código se genera normalmente sin embargo no se copia inmediatamente en las Celdas “B5” sino que aparece en las Celdas “B6” mientras que las Celdas “B5” siempre permanecen en blanco, actualmente el código consta de tres letras y cuatro dígitos (RCI-0000) pero me interesa poderle concatenar el mes y año en formato mm-yy para que el código finalmente quede expresado de la siguiente forma RCI-0000-00-00 Mucho les sabre agradecer la ayuda que me puedan dar RCI PRUEBA..xlsm
    • Saludos amigos espero estén bien  En la actualidad  los datos provenientes de los TextBox 5, 6 y 7 se guardan en las Columnas H, I y O de las Hojas 58 (MATRIZ1) y Hojas59 (MATRIZ2) sin embargo cuando el texto es abundante no se visualiza completamente en las celdas correspondientes de allí que necesito que cada fila se ajuste al tamaño de la celda que contenga mayor cantidad de texto para lo cual he probado con la siguiente macro: Private Sub Worksheet_SelectionChange(ByVal Target As Range) Cells.EntireRow.AutoFit End Sub Sin embargo, dicha macro coloca todas las filas del tamaño del texto que contengan y lo que en realidad necesito es que dicha macro solo se aplique desde la Fila 5 en adelante. Mucho les sabre agradecer la ayuda que me puedan dar RCI PRUEBA..xlsm
    • Saludos amigos espero estén bien  En la actualidad utilizo la siguiente macro para que la fecha aparezca en el Textbox2: Private Sub UserForm_activate() Me.TextBox2.Value = VBA.Date End Sub Sin embargo, una vez guardo los datos la fecha cambia de formato y se guarda en formato mm/dd/yyyy en vez de dd/mm/yyyy y este cambio de fecha me distorsiona los resultados de las fórmulas en las Columnas J en las Hojas 58 (MATRIZ1) y Hojas59 (MATRIZ2) Mucho les sabre agradecer la ayuda que me puedan dar RCI PRUEBA..xlsm
    • ¡Hola! Después de un buen tiempo ausente...  @Gabriela hg ya que veo que tienes Excel 365, te dejo mi solución para piezas y gramos.   Extraer piezas - gramos 365_GP.xlsx
  • Visualizado recientemente

    • No hay usuarios registrado para ver esta página.
×
×
  • Crear nuevo...

Información importante

Echa un vistazo a nuestra política de cookies para ayudarte a tener una mejor experiencia de navegación. Puedes ajustar aquí la configuración. Pulsa el botón Aceptar, si estás de acuerdo.