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 Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 20-07-2004
burasu burasu is offline
Miembro
 
Registrado: may 2003
Ubicación: Cádiz - España
Posts: 183
Poder: 22
burasu Va por buen camino
Como concateno cadenas en Firebird?¿?

Hola vereis, estoy haciendo una aplicación de contabilidad y tengo un problema, debo actualizar una serie de datos que son una cuentas contables. Tengo que insertar en mitad de la cadena de la cuenta un par de ceros, y no tengo muy clara la sentencia que debo utilizar.

Uso algo como esto:
Código:
update cuentas set ccuenta = substr(ccuenta,1,4) + '00' + substr(ccuenta,4,4)
where strlen(ccuenta)=8
Y lo que me devuelve es algo como esto 400.0000000, y me resultaría más como hacerlo por sql que no ponerme a realizar ahora una aplicación.

Como podría arreglarlo?
Responder Con Cita
  #2  
Antiguo 20-07-2004
Gydba Gydba is offline
Miembro
 
Registrado: ene 2004
Ubicación: Argentina
Posts: 673
Poder: 21
Gydba Va por buen camino
Buenos días,

Primero supongo que los campos que estás trabajando son cadenas, segundo para concatenarlas se utiliza ||

Ejemplo:
Código SQL [-]
update cuentas set ccuenta = substr(ccuenta,1,4) || '00' || substr(ccuenta,4,4)
where strlen(ccuenta)=8

PD: No probé nada por lo cual algo me puedo estar comiendo, pero esa mas o menos es la idea.
Saludos!
__________________
Suerte
.: Gydba :.
Responder Con Cita
  #3  
Antiguo 20-07-2004
burasu burasu is offline
Miembro
 
Registrado: may 2003
Ubicación: Cádiz - España
Posts: 183
Poder: 22
burasu Va por buen camino
Gracias Gydba, me has ahorrado mucho trabajo, lo que no entiendo es porque antes esa misma sentencia no me funcionó? Bueno da igual lo dicho gracias.
Responder Con Cita
  #4  
Antiguo 20-07-2004
Gydba Gydba is offline
Miembro
 
Registrado: ene 2004
Ubicación: Argentina
Posts: 673
Poder: 21
Gydba Va por buen camino
¿Cómo que no te funcionó? ¿Ahora si anduvo?
__________________
Suerte
.: Gydba :.
Responder Con Cita
  #5  
Antiguo 20-07-2004
Julià T. Julià T. is offline
Miembro
 
Registrado: may 2003
Ubicación: en el teclado
Posts: 314
Poder: 22
Julià T. Va por buen camino
Si las cadenas a concatenar continen valores "null", creo que no funciona, al igual que sumar valores null.
Responder Con Cita
  #6  
Antiguo 21-07-2004
Avatar de ACK
ACK ACK is offline
Miembro
 
Registrado: jun 2003
Ubicación: Castellón
Posts: 27
Poder: 0
ACK Va por buen camino
En Interbase, cuando uno de los campos a concatenar es nulo, el resultado de la concatenación es siempre nulo. Supongo que en Firebird será igual.

Saludos
Responder Con Cita
  #7  
Antiguo 21-07-2004
Gydba Gydba is offline
Miembro
 
Registrado: ene 2004
Ubicación: Argentina
Posts: 673
Poder: 21
Gydba Va por buen camino
Vale esa aclaración...

Pero con algo del tipo:
Código SQL [-]
SELECT COALESCE(CAMPO1, '') || COALESCE(CAMPO2, '') FROM TABLA
Se arreglaría. Esto es en Firebird 1.5
__________________
Suerte
.: Gydba :.
Responder Con Cita
Respuesta



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


La franja horaria es GMT +2. Ahora son las 19:59:02.


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