FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
SELECT con SUBSTRING en Firebird
Tengo este query:
A la hora de tratar de ejecuatrlo, tanto desde programa como con IBManager, me da este error: Cita:
|
#2
|
|||
|
|||
Esto:
LEFT JOIN Bancos H ON SUBSTRING(A.Iban FROM 5 FOR 4) = H.Codigo AND A.IdCuenta = 'A' ¿No debería ir así? LEFT JOIN Bancos H ON (SUBSTRING(A.Iban FROM 5 FOR 4) = H.Codigo) AND (A.IdCuenta = 'A') |
#3
|
||||
|
||||
|
#4
|
||||
|
||||
Hay que tener en cuenta que existe unas UDF que implementan el substring y lo usan de una forma diferente, así que es bueno ver que en los códigos del UDF no se encuentre creado substring, también sría bueno saber que versión de Firebird usa? H.Codigo es un string o un int?
Por último y aunque no creo que afecte mucho podrías cambiar el orden a lo siguiente:
__________________
"Como pasa el tiempo..... ayer se escribe sin H y hoy con H" |
#5
|
||||
|
||||
Gracias por las respuestas.
Cita:
Cita:
Cita:
|
#6
|
||||
|
||||
¡Mi gozo en un pozo!
Al margen de que, efectivamente, había renombrado alguna columna y se me había olvidado el problema no era esa. Sigue dándome el mismo error; por si acaso he actualizado a la versión 2.5.4 de Firebird. Voy más allá: Estoy probando este otro código:
Las tablas son estas: Cita:
Cita:
Hasta donde veo el código es correcto; de hecho en una BB.DD. Paradox funciona sin ningún problema. Sin embargo usando tanto IBManager como IBExpert me da el mismo error: Cita:
|
#7
|
||||
|
||||
Si hace falta y alguien me puede ayudar le mando las tablas implicadas.
|
#8
|
||||
|
||||
Es que por lo visto tiene que ser "select substring" no en un "where".
Puedes crearte un Stored Procedure, algo asi como:
|
#9
|
||||
|
||||
Hola Angel.Matilla.
Algo mas debe haber en juego. Reproduje la situación como la planteaste, ejecutando la misma consulta y no me dá ningún error. Ambiente: Código:
Windows 7 32 bit. Firebird 2.5.0 IBExpert 2015.6.17.1 Tabla PAISES: Código:
CODIGO NOMBRE ---------------- 156 CHINA 840 E.E.U.U. 124 CANADA Código:
ENTIDAD NOMBRE BIC -------------------------------------------- 00001 ICBC 000015600000 00002 Wells Fargo & Co 000084000000 00003 Bank of Nova Scotia 000012400000
Resultado: Código:
ENTIDAD NOMBRE BIC -------------------------------------------- 00001 ICBC 000015600000 00002 Wells Fargo & Co 000084000000 00003 Bank of Nova Scotia 000012400000 Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#10
|
||||
|
||||
A mi también me corre bien el query así tal cual está, con esos tipos de datos (osea BIC varchar(12) y CODIGO varchar(3),
por otro lado el query no es optimo y con muchos registros en ambas tamblas podría tomar mucho tiempo, lo puedes cambiar a algo similar a esto:
__________________
"Como pasa el tiempo..... ayer se escribe sin H y hoy con H" |
#11
|
||||
|
||||
Gracias a todos por las respuestas.
Cita:
Código SQL [-]SELECT SUBSTRING(Bic FROM 5 FOR 2) FROM Bancos me da el mismo error Cita:
Cita:
Cita:
Me da el mismo error: TOKEN UNKNOW FROM. Última edición por Angel.Matilla fecha: 18-07-2015 a las 11:49:54. |
#12
|
||||
|
||||
A lo mejor digo una tontería: ¿Puede tener algo que ver con la definición de la base de datos? Es que no se me ocurre otra cosa. La definición, que se hace por código, es esta:
Código:
IBDatabase1->Params->Clear(); IBDatabase1->DatabaseName = "Afiliados.gdb"; IBDatabase1->Params->Add("USER 'sysdba'"); IBDatabase1->Params->Add("PASSWORD 'masterkey'"); IBDatabase1->Params->Add("PAGE_SIZE 4096"); IBDatabase1->SQLDialect = 3; IBDatabase1->CreateDatabase(); |
#13
|
||||
|
||||
Hola Angel.Matilla
Cita:
Código PHP:
Cita:
Cita:
Cita:
¿ Has intentado reinstalar Firebird ? Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#14
|
||||
|
||||
Hola
divide y vencerás. Yo no veo nada raro en la query. Si haces SELECT SUBSTRING(BIC FROM 5 FOR 3) FROM BANCOS tiene que darte los códigos de los países. Si haces SELECT CODIGO FROM PAISES tiene que darte los códigos también. si haces SELECT SUBSTRING(B.BIC FROM 5 FOR 3) FROM BANCOS B inner join PAISES P ON ( SUBSTRING(B.BIC FROM 5 FOR 3) = P.codigo) tiene que darte los códigos de los países que reconcilian en las dos tablas. Si has llegado hasta aqui, no vas mal. Si en lugar de INNER JOIN pones LEFT JOIN.... y añades una pequeña condición... tienes tu consulta. Esto debe funcionar desde la versión 0 de FB, no lo aseguro pero me apostaría un Kas de limón. Ya nos contarás. Postea tus resultados. Un saludo
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino - |
#15
|
||||
|
||||
Yo me apuesto una Mirinda
|
#16
|
||||
|
||||
O una Konga naranja Cuánto ha llovido.... sniff
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino - |
#17
|
||||
|
||||
Gracias por vuestras respuestas. El Kas, la Mirinda o la Konga la pago yo si arreglo el follón .
Está añadfido y, efectivamente, no tiene ningún efecto. En la definición de las tablas me he dado cuenta que se me olvidó aclarar una cosa: Los campos VARCHAR están dimensionados con exceso; es decir: tuve que poner en toos los VARCHAR de la base de datos una posición más de las necesarias porque, y tampocó sé la razón, si los ponía justos al hacer un SELECT del tipo LIKE '99%' me daba error. Así pues el código de país realmente tiene dos posiciones: ES para España, FR para Francia, US para los Estados Unidos, etc. En ese sentido ecfisa tiene razón en que el resultado de su query es coherente; ¡error mío! Sí, actualizándolo a la última versión estable, la 2.5.4 El problema es que me dice que la palabra reservada FROM le es desconocida, y es esto lo que me tiene perplejo. Ponga donde ponga el SUBSTRING (como parte del SELECT o como parte del WHERE) me da siempre el mismo error: Cita:
Cita:
|
#18
|
||||
|
||||
Hola,
sin mucha convicción te lo digo. Has eliminado la dll de firebird de donde proceda?. fbclient.dll . Búscala, bórrala y sustituyela por la incluida en la última versión que hayas instalado. Podría ser que tengas mezcladas versiones de fb y la librería cliente. Saludos
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino - |
#19
|
||||
|
||||
Desde luego que "normal" no es eso.
|
#20
|
||||
|
||||
Parece ser que todo es debido a una instalación anterior de Interbase XE que juraría había desinstalado. Aunque no estaba conectado el servidor, la base de datos se ha creado como si fuera de Interbase o eso es lo que me han indicado desde EMS:
Cita:
|
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Replace con substring en Firebird | nuxbaster | Firebird e Interbase | 3 | 18-01-2015 18:56:49 |
select * en firebird | Carlos Lesca | Firebird e Interbase | 1 | 22-02-2011 21:45:40 |
Select de Dos BD´s distintas en Firebird 2.1 | angelholberg | Conexión con bases de datos | 2 | 18-02-2009 19:55:10 |
Problema con select first en Firebird | egostar | Firebird e Interbase | 20 | 17-07-2007 21:55:11 |
error Select firebird 1.5 | ale21alito | Firebird e Interbase | 2 | 25-04-2005 20:20:03 |
|