Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 16-06-2015
pape19 pape19 is offline
Miembro
 
Registrado: jul 2010
Posts: 96
Poder: 14
pape19 Va por buen camino
Pasar parámetro que sea una cadena de números

Buenas tardes, me encuentro con el siguiente problema.

Tengo una tabla en una base de datos firebird en la cual guardo diferentes querys(una por registro). Al necesitar una...creo un objeto IBQuery por código, y le asigno el código de la query de un registro de esa tabla.

En este caso tengo la siguiente consulta.

Código SQL [-]
SELECT  CTR_LOG_PEDIDOS_DET.RZ_CLIENTE,
            SUM (CTR_LOG_PEDIDOS_DET.CANT_BULTOS)
FROM CTR_LOG_PEDIDOS_DET
WHERE   CAST(CTR_LOG_PEDIDOS_DET.RETIRO_TRANSP AS DATE) >= :FECINI
AND       CAST(CTR_LOG_PEDIDOS_DET.RETIRO_TRANSP AS DATE) <= :FECFIN
AND       CTR_LOG_PEDIDOS_DET.TRANSP_ID IN ( :qCadena )
GROUP BY CTR_LOG_PEDIDOS_DET.RZ_CLIENTE

En el código, en delphi, tengo lo siguiente.

Código Delphi [-]
IBQuery1.ParamByName('Qcadena').Text := cadenaTransportes;

cadenaTransportes es un string que equivale a '11, 20, 31, 4'.

Al abrir la query obtengo la excepción:
"conversion error from string "11, 20, 31, 4"

Como puedo solucionar esto??

Muchas gracias!
Responder Con Cita
  #2  
Antiguo 16-06-2015
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.037
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Puede ser:
Código Delphi [-]
IBQuery1.ParamByName('Qcadena').Text := #39+cadenaTransportes+#39;
o también
Código Delphi [-]
IBQuery1.ParamByName('Qcadena').Text := QuotedStr(cadenaTransportes);

Última edición por Casimiro Notevi fecha: 16-06-2015 a las 22:46:44.
Responder Con Cita
  #3  
Antiguo 16-06-2015
pape19 pape19 is offline
Miembro
 
Registrado: jul 2010
Posts: 96
Poder: 14
pape19 Va por buen camino
Casimiro, gracias por la pronta respuesta.

En esos casos me da el mismo error, con comillas simples, de la siguiente forma.

conversion error from string "'11, 20, 31, 4'"

Un dato aparte y que puede servir...es que si en lugar de tomar el valor almacenado de la tabla; escribo el SQL en delphi, funciona bien.

Código Delphi [-]
IBQuery.SQL.Text := 'SELECT  CTR_LOG_PEDIDOS_DET.RZ_CLIENTE, ' +
                                          'SUM (CTR_LOG_PEDIDOS_DET.CANT_BULTOS) ' +
                                          'FROM CTR_LOG_PEDIDOS_DET ' +
                                          'WHERE   CAST(CTR_LOG_PEDIDOS_DET.RETIRO_TRANSP AS DATE) >= :FECINI ' +
                                          'AND       CAST(CTR_LOG_PEDIDOS_DET.RETIRO_TRANSP AS DATE) <= :FECFIN ' +
                                          'AND       CTR_LOG_PEDIDOS_DET.TRANSP_ID IN ( :qCadena ) ' +
                                          'GROUP BY CTR_LOG_PEDIDOS_DET.RZ_CLIENTE ';
Responder Con Cita
  #4  
Antiguo 16-06-2015
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola pape19.

Mirando ahora con mas detalle, veo que RZ_CLIENTE es el identificador de la tabla, seguramente de tipo INTEGER. Y es que de el modo que lo estás haciendo, Firebird jamás sabra que lo que intentas pasar como parámetro es una lista de enteros separados por comas...

Lo que precisas hacer es algo así: How to input an array parameter of values to Firebird Stored Procedure? ( mensaje 2)

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #5  
Antiguo 16-06-2015
pape19 pape19 is offline
Miembro
 
Registrado: jul 2010
Posts: 96
Poder: 14
pape19 Va por buen camino
Muchisimas gracias Ecfisa! Excelente solución!
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Contar y reemplazar una cadena de numeros darkbits Varios 9 11-03-2011 22:05:16
Como pasar un parametro? b3nshi Varios 3 18-08-2007 06:54:53
Separar cadena de numeros cyborgve Impresión 1 16-05-2007 06:37:31
Quitar todos los números de una cadena dec Trucos 0 07-06-2006 20:04:33
pasar parametro pharaonhx Conexión con bases de datos 3 10-05-2006 19:02:50


La franja horaria es GMT +2. Ahora son las 22:32:53.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi