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 30-01-2008
Avatar de linuz
linuz linuz is offline
Miembro
 
Registrado: sep 2004
Posts: 88
Poder: 20
linuz Va por buen camino
De varchar a integer

Hola a todos,

He buscado informado acerca de como poder pasar una cadena de texto a un entero en FireBird 1.5, pero no he encontrado exactamente si se puede hacer.

Si alguno de ustedes sabe si es posible le agradecería mucho que me dijera como se puede.


Muchas gracias.


Un saludo.
Responder Con Cita
  #2  
Antiguo 30-01-2008
luisgutierrezb luisgutierrezb is offline
Miembro
 
Registrado: oct 2005
Ubicación: México
Posts: 925
Poder: 19
luisgutierrezb Va por buen camino
generalmente funciona:

Código SQL [-]
Cast(CampoCadena as INTEGER)
Responder Con Cita
  #3  
Antiguo 30-01-2008
Avatar de linuz
linuz linuz is offline
Miembro
 
Registrado: sep 2004
Posts: 88
Poder: 20
linuz Va por buen camino
He probado a poner
Código SQL [-]
cast (cadena as INTEGER)
me compila bien, pero no funciona para lo que quiero hacer.

Lo que me interesa hacer es coger 2 caracteres de una cadena de texto, y pasarlos a un entero.

Os pongo un trozo del codigo:

Código SQL [-]
 for select empresa,cod_postal,codigo_cliente,num_direccion from cli_direcciones
     into :empresa,:codigo_postal,:cliente,:direccion do
     begin
      provincia2 = substrlen(codigo_postal,1,2);
      provincia = cast(provincia2 as INTEGER);
...


¿Alguna idea?

Muchas gracias.
Responder Con Cita
  #4  
Antiguo 30-01-2008
Avatar de jhonny
jhonny jhonny is offline
Jhonny Suárez
 
Registrado: may 2003
Ubicación: Colombia
Posts: 7.058
Poder: 30
jhonny Va camino a la famajhonny Va camino a la fama
Cita:
Empezado por linuz Ver Mensaje
He probado a poner
Código SQL [-]
cast (cadena as INTEGER)
me compila bien, pero no funciona para lo que quiero hacer.

Lo que me interesa hacer es coger 2 caracteres de una cadena de texto, y pasarlos a un entero.

Os pongo un trozo del codigo:

Código SQL [-]
 for select empresa,cod_postal,codigo_cliente,num_direccion from cli_direcciones
     into :empresa,:codigo_postal,:cliente,:direccion do
     begin
      provincia2 = substrlen(codigo_postal,1,2);
      provincia = cast(provincia2 as INTEGER);
...


¿Alguna idea?

Muchas gracias.
Pues lo unico que veo mal según lo que te entiendo, es que no es substrlen si no substring y se usa asi:

Código SQL [-]
 for select empresa,cod_postal,codigo_cliente,num_direccion from cli_direcciones
     into :empresa,:codigo_postal,:cliente,:direccion do
     begin
      provincia2 = substring(codigo_postal FROM 1 FOR 2);
      provincia = cast(provincia2 as INTEGER);
...

Espero te sirva.
__________________
Lecciones de mi Madre. Tema: modificación del comportamiento, "Pará de actuar como tu padre!"

http://www.purodelphi.com/
http://www.nosolodelphi.com/
Responder Con Cita
  #5  
Antiguo 31-01-2008
Avatar de linuz
linuz linuz is offline
Miembro
 
Registrado: sep 2004
Posts: 88
Poder: 20
linuz Va por buen camino
Hola,

He probado a cambiar el código poniendo:
Código SQL [-]
provincia2 = substring(codigo_postal FROM 1 FOR 2);
Efectivamente el código es correcto, pero me sigue cogiendo una cadena de texto y no un entero.
No se como puedo hacer esto.

Ante todo muchas gracias por vuestra ayuda.

Un saludo.
Responder Con Cita
  #6  
Antiguo 31-01-2008
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 29
Lepe Va por buen camino
Pues otra vuelta de tuerca más:

Código SQL [-]
provincia2 = cast( substring(codigo_postal FROM 1 FOR 2) as integer);

Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente,
se lo volveré a explicar hasta que no lo entienda, Gracias.
Responder Con Cita
  #7  
Antiguo 31-01-2008
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
Y otra vuelta de tuerca mas.. :D
Código SQL [-]
for select empresa, cod_postal, codigo_cliente, num_direccion,
           cast( substring(cod_postal FROM 1 FOR 2) as integer)
      from cli_direcciones
      into :empresa, :codigo_postal, :cliente, :direccion, :provincia do
begin
  /*lo que haya que hacer!*/

Hasta luego.

;)
__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #8  
Antiguo 31-01-2008
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 29
Lepe Va por buen camino
.... Al final lo "pasaremos de rosca".... fijo .


Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente,
se lo volveré a explicar hasta que no lo entienda, Gracias.
Responder Con Cita
  #9  
Antiguo 31-01-2008
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
jajaja... ya lo creo
__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #10  
Antiguo 01-02-2008
Avatar de linuz
linuz linuz is offline
Miembro
 
Registrado: sep 2004
Posts: 88
Poder: 20
linuz Va por buen camino
Hola,

Gracias por vuestras respuestas , pero he intentado dandole muchas vueltas de rosca, pero sigue sin funcionar. Lo que pasa es que el campo varchar al compararse con un integer me da el tipico error de "Convertion error from string".

No se que hacer, seguramente me tocara hacerlo en delphi, pero prefiero hacerlo sobre la base de datos, y asi no tener que andar a actualizando a clientes, jeje .

SI os ocurre alguna cosa más estaré por aqui.

Gracias por vuestra atención.

Saludos.
Responder Con Cita
  #11  
Antiguo 01-02-2008
Avatar de jhonny
jhonny jhonny is offline
Jhonny Suárez
 
Registrado: may 2003
Ubicación: Colombia
Posts: 7.058
Poder: 30
jhonny Va camino a la famajhonny Va camino a la fama
Cita:
Empezado por linuz Ver Mensaje
Hola,

Gracias por vuestras respuestas , pero he intentado dandole muchas vueltas de rosca, pero sigue sin funcionar. Lo que pasa es que el campo varchar al compararse con un integer me da el tipico error de "Convertion error from string".

No se que hacer, seguramente me tocara hacerlo en delphi, pero prefiero hacerlo sobre la base de datos, y asi no tener que andar a actualizando a clientes, jeje .

SI os ocurre alguna cosa más estaré por aqui.

Gracias por vuestra atención.

Saludos.
Suguramente los datos que esta devolviendo el substring son alfanumericos, tendras que adecuar el ejemplo a tu necesidad, nosotros hemos asumido que el valor que necesitas esta comprendido entre la posicion 0 y 1 de tu cadena de texto, ya que tu no nos haz mostrado como estan compuestos dichos codigos, por lo que tendras que mover un poco esas posiciones si ese es el caso.
__________________
Lecciones de mi Madre. Tema: modificación del comportamiento, "Pará de actuar como tu padre!"

http://www.purodelphi.com/
http://www.nosolodelphi.com/
Responder Con Cita
  #12  
Antiguo 03-02-2008
Avatar de PepeLolo
PepeLolo PepeLolo is offline
Miembro
 
Registrado: jun 2003
Ubicación: Fuenlabrada - Madrid - Espagna
Posts: 265
Poder: 21
PepeLolo Va por buen camino
Talking

Buenas, me parece que el problema está en la variable destino, esta debe ser de tipo INTEGER, en caso contrario te dará el error que indicas.
De todas formas debes estar seguro que el valor del campo o la subcadena que extraigas contenga valores comprendidos entre "0" y "9", no importa que el valor extraido de la cadena sea "08" al realizar la conversión esta se transformara en un 8.

Ejemplo:
Código SQL [-]
Provincia = cast(cdprov as integer)

Saludos.
__________________
PepeLolo
El hombre el único virus que mide más de unas cuantas micras
Responder Con Cita
  #13  
Antiguo 04-02-2008
Avatar de linuz
linuz linuz is offline
Miembro
 
Registrado: sep 2004
Posts: 88
Poder: 20
linuz Va por buen camino
Hola de nuevo,

He llevado a cabo vuestros consejos, pero no ha habido forma de conseguir mi propósito.

Os dejo el código del procedimiento. Su funcionamiento es simple, se trata de coger los dos primeros caracteres del código postal, y con ello cojo lo provincia y población de otra tabla, para así modificar la ficha del cliente.

Código SQL [-]
create procedure actualiza_codigo_postales 
as
declare variable postal integer;
declare variable codigo_postal varchar(10);
declare variable provincia integer;
declare variable poblacion integer;
declare variable cliente smallint;
declare variable empresa smallint;
declare variable direccion smallint;
begin
   for select empresa,cod_postal,codigo_cliente,num_direccion from cli_direcciones
     into :empresa,:codigo_postal,:cliente,:direccion do
     begin
     if ((codigo_postal <> '') or (codigo_postal is not null)) then
       begin
         provincia = cast( substring(codigo_postal FROM 1 FOR 2) as integer);
         if (provincia > 0) then 
           begin       
             select codigo from poblaciones
             where cod_postal =:codigo_postal
              and   provincia = : provincia
               into : poblacion;
               
            if (poblacion is null) then poblacion = 0;
            if (provincia is null) then provincia = 0;
            
              update cli_direcciones 
               set provincia = : provincia,poblacion = : poblacion
               where empresa        =:empresa
               and   codigo_cliente =:cliente
               and   num_direccion  =:direccion;
          end
       end
     end   
  suspend;
end

Un saludo.

MUCHAS GRACIAS A TODOS!!
Responder Con Cita
  #14  
Antiguo 12-02-2008
Avatar de PepeLolo
PepeLolo PepeLolo is offline
Miembro
 
Registrado: jun 2003
Ubicación: Fuenlabrada - Madrid - Espagna
Posts: 265
Poder: 21
PepeLolo Va por buen camino
Talking

Si te falla la sentencia
Código SQL [-]
provincia = cast( substring(codigo_postal FROM 1 FOR 2) as integer);
es porque en las posiciones que extraes en alguno de los registros no hay números.

Ejecuta la consulta y revisa el resultado porque el problema lo tienes ahí.
Código SQL [-]
select empresa,cod_postal,codigo_cliente,num_direccion from cli_direcciones

Un saludo
__________________
PepeLolo
El hombre el único virus que mide más de unas cuantas micras
Responder Con Cita
  #15  
Antiguo 12-02-2008
Avatar de RolphyReyes
RolphyReyes RolphyReyes is offline
Miembro
 
Registrado: ago 2004
Ubicación: Santo Domingo
Posts: 285
Poder: 20
RolphyReyes Va por buen camino
Lightbulb

Saludos.

Tal como dice PepeLolo debes de tener alguna cadena nula o algo por el estilo.

Te recomiendo utilizar COALESCE para que mandes un valor que te sirva para identificar que esa cadena ha fallado.

Hasta luego.
__________________
Gracias,
Rolphy Reyes
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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
pasar un varchar hh:mm:ss a integer de segundos jmlifi SQL 5 02-05-2006 11:00:54
Cambio de dominio en un Varchar Ana Tudela Firebird e Interbase 1 10-01-2006 21:17:12
Cambiar dominio VARCHAR micayael Firebird e Interbase 1 24-09-2005 00:30:50
trim en campos varchar galmacland SQL 3 12-03-2005 02:40:23
varchar (10) scooterjgm SQL 4 11-11-2004 13:21:02


La franja horaria es GMT +2. Ahora son las 02:46:50.


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