Utilizamos cookies propias y de terceros. Al navegar entendemos que aceptas el uso de cookies. +Info.
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Error ORA-01722
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Error ORA-01722

Publicar nuevo tema Responder al tema
Foros de discusión » Oracle Database, motor de base de datos profesional   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Error ORA-01722 Responder citando

Estoy desarrollando una aplicación con Visual Studio .Net, he de ejecutar una consulta SQL, pero cuando lo hago, en determinados registros me devuelve este error:

---------------------------
Facturación y Contabilidad
---------------------------
Error al ejecutar consulta SQL: ORA-01722: invalid number

---------------------------
Aceptar
---------------------------




La consulta SQL que ejecuto:

Código:

select num_factura, fecha_factura,
    TO_CHAR(banco_factura, '0000')  || '-' ||
    TO_CHAR(sucursal_factura, '0000')  || '-' || 
    TO_CHAR(digito_control_factura, '00')  || '-' || 
    TO_CHAR(cuenta_factura, '0000000000') as CCC
from facturacion
where cod_cliente_factura = 69 and
    obs_factura like '%AjpdSoft%'


¿a qué puede ser debido?
MensajePublicado:
Lun Ago 24, 2009 5:51 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error ORA-01722 Responder citando

varios escribió:
Estoy desarrollando una aplicación con Visual Studio .Net, he de ejecutar una consulta SQL, pero cuando lo hago, en determinados registros me devuelve este error:

---------------------------
Facturación y Contabilidad
---------------------------
Error al ejecutar consulta SQL: ORA-01722: invalid number

---------------------------
Aceptar
---------------------------




La consulta SQL que ejecuto:

Código:

select num_factura, fecha_factura,
    TO_CHAR(banco_factura, '0000')  || '-' ||
    TO_CHAR(sucursal_factura, '0000')  || '-' || 
    TO_CHAR(digito_control_factura, '00')  || '-' || 
    TO_CHAR(cuenta_factura, '0000000000') as CCC
from facturacion
where cod_cliente_factura = 69 and
    obs_factura like '%AjpdSoft%'


¿a qué puede ser debido?


Por el error que nos comentas, el ORA-01722, y la consulta SQL, el error lo devuelve la función de Oracle TO_CHAR, en alguna de las que utilizas, no es capaz de convertir el texto al formato indicado, porque espera un número y el campo contiene otra cosa.

Lo primero que te recomendamos es que "aisles" el error, es decir, que compruebes en qué campo está dándote el error (banco_factura, sucursal_factura, digito_control_factura, cuenta_factura), haciendo el mismo Select pero sólo con uno de los campos, así hasta que veas cuál es el que te da el error (o si son varios).

Luego puedes ejecutar un select con ese campo, pero sin la función "TO_CHAR", así verás por qué te da el error.
MensajePublicado:
Lun Ago 24, 2009 6:01 am
Top of PageVer perfil de usuario
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Re: Error ORA-01722 Responder citando

alonsojpd escribió:
Por el error que nos comentas, el ORA-01722, y la consulta SQL, el error lo devuelve la función de Oracle TO_CHAR, en alguna de las que utilizas, no es capaz de convertir el texto al formato indicado, porque espera un número y el campo contiene otra cosa.

Lo primero que te recomendamos es que "aisles" el error, es decir, que compruebes en qué campo está dándote el error (banco_factura, sucursal_factura, digito_control_factura, cuenta_factura), haciendo el mismo Select pero sólo con uno de los campos, así hasta que veas cuál es el que te da el error (o si son varios).

Luego puedes ejecutar un select con ese campo, pero sin la función "TO_CHAR", así verás por qué te da el error.


Ok, he hecho lo que me has dicho, el error viene por el campo "digito_control", que en determinados registros aparece "**". Pero ¿cómo puedo arreglar esto? necesito que la consulta SQL me devuelva el número de cuenta (CCC) formateado del tipo:

0000-0000-00-0000000000

Con los ceros a la izquierda necesarios para que siempre aparezca con el mismo tamaño. Si la función TO_CHAR da error ¿qué otra función puedo utilizar que no dé error? ¿por qué da error la función TO_CHAR si en realidad se trata de convertir a cadena de texto y el campo contiene un texto "**"?
MensajePublicado:
Lun Ago 24, 2009 6:04 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error ORA-01722 Responder citando

varios escribió:
Ok, he hecho lo que me has dicho, el error viene por el campo "digito_control", que en determinados registros aparece "**". Pero ¿cómo puedo arreglar esto? necesito que la consulta SQL me devuelva el número de cuenta (CCC) formateado del tipo:

0000-0000-00-0000000000

Con los ceros a la izquierda necesarios para que siempre aparezca con el mismo tamaño. Si la función TO_CHAR da error ¿qué otra función puedo utilizar que no dé error? ¿por qué da error la función TO_CHAR si en realidad se trata de convertir a cadena de texto y el campo contiene un texto "**"?


Te da error por la máscara de formato que utilizas "00", lo que hace la función TO_CHAR es primero convertir a número y luego a texto, puesto que le estás indicando que el resultado devuelto (por la máscara de formato) sea un número, si no lo es dará error.

Hay varias formas de solucionar tu problema, una de ellas, tal vez la más sencilla es utilizar la función DECODE antes de TO_CHAR:

http://www.ajpdsoft.com/modules.php?name=Encyclopedia&op=content&tid=682

Tu consulta SQL quedaría de la siguiente forma:

Código:

select num_factura, fecha_factura,
    TO_CHAR(banco_factura, '0000')  || '-' ||
    TO_CHAR(sucursal_factura, '0000')  || '-' ||
    TO_CHAR(DECODE(digito_control_factura, '**', '0', digito_control_factura), '00')  || '-' ||
    TO_CHAR(cuenta_factura, '0000000000') as CCC
from facturacion
where cod_cliente_factura = 69 and
    obs_factura like '%AjpdSoft%'


La función DECODE es como un "si", una condición, si el valor del campo es "**" devolverá "0" y sino devolverá el valor del campo. De esta forma, si el valor es "**" al devolver "0" la función TO_CHAR ya no te dará error.

Este método tiene un pequeño problema y es si alguna vez no hay un "**" y hay otro carácter, como "*", en este caso la condición no se cumplirá y te volvería a dar error.
MensajePublicado:
Lun Ago 24, 2009 6:37 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error ORA-01722 Responder citando

La forma más elegante es crear una función en Oracle que te devuelva verdadero o falso y que compruebe sis es un número o no, sería algo así:

Código:

CREATE OR REPLACE FUNCTION esNumero (texto IN VARCHAR2)
  RETURN BOOLEAN IS numero NUMBER;
BEGIN
  numero := TO_NUMBER (texto);
  RETURN TRUE;
  EXCEPTION WHEN OTHERS THEN
    RETURN FALSE;
END;



Para usarla sería algo así:

Código:

select num_factura, fecha_factura,
    TO_CHAR(banco_factura, '0000')  || '-' ||
    TO_CHAR(sucursal_factura, '0000')  || '-' ||
    TO_CHAR(DECODE(esNumero(digito_control_factura), 'False', '0', digito_control_factura), '00')  || '-' ||
    TO_CHAR(cuenta_factura, '0000000000') as CCC
from facturacion
where cod_cliente_factura = 69 and
    obs_factura like '%AjpdSoft%'
MensajePublicado:
Lun Ago 24, 2009 9:38 am
Top of PageVer perfil de usuario
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Re: Error ORA-01722 Responder citando

alonsojpd escribió:
La forma más elegante es crear una función en Oracle que te devuelva verdadero o falso y que compruebe sis es un número o no, sería algo así:

Código:

CREATE OR REPLACE FUNCTION esNumero (texto IN VARCHAR2)
  RETURN BOOLEAN IS numero NUMBER;
BEGIN
  numero := TO_NUMBER (texto);
  RETURN TRUE;
  EXCEPTION WHEN OTHERS THEN
    RETURN FALSE;
END;



Para usarla sería algo así:

Código:

select num_factura, fecha_factura,
    TO_CHAR(banco_factura, '0000')  || '-' ||
    TO_CHAR(sucursal_factura, '0000')  || '-' ||
    TO_CHAR(DECODE(esNumero(digito_control_factura), 'False', '0', digito_control_factura), '00')  || '-' ||
    TO_CHAR(cuenta_factura, '0000000000') as CCC
from facturacion
where cod_cliente_factura = 69 and
    obs_factura like '%AjpdSoft%'


Esta es buena idea, pero no tengo permisos suficientes para crear funciones y no soy administrador de la base de datos.

Efectivamente, el campo del dígito de control puede llevar caracteres diferentes a "**" ¿hay otra solución sin utilizar funciones de Oracle creadas por el usuario?
MensajePublicado:
Lun Ago 24, 2009 11:12 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error ORA-01722 Responder citando

varios escribió:
Esta es buena idea, pero no tengo permisos suficientes para crear funciones y no soy administrador de la base de datos.

Efectivamente, el campo del dígito de control puede llevar caracteres diferentes a "**" ¿hay otra solución sin utilizar funciones de Oracle creadas por el usuario?


Entonces podrías utilizar una consulta SQL como la siguiente:

Código:

select decode(length(translate(trim(nombre_campo),
    ' +-.0123456789',' ')), '','Número', 'No número')
from dual


Esta consulta SQL devolverá "Número" si el valor de "nombre_campo" lleva algún número, en caso contrario (si lleva una letra o carácter especial), devolverá "No número".

Para utilizarla en tu caso podría ser algo así:

Código:

select num_factura, fecha_factura,
    TO_CHAR(banco_factura, '0000')  || '-' ||
    TO_CHAR(sucursal_factura, '0000')  || '-' ||
    TO_CHAR(DECODE(
        select decode(length(translate(trim(digito_control_factura),
            ' +-.0123456789',' ')), '','Número', 'No número'),
        'No número', '0', digito_control_factura), '00')  || '-' ||
    TO_CHAR(cuenta_factura, '0000000000') as CCC
from facturacion
where cod_cliente_factura = 69 and
    obs_factura like '%AjpdSoft%'


Ten en cuenta que la consulta SQL que te proponemos para comprobar si es o no un número el contenido del campo no funcionará si hay algo así:

98.-.++89

Lo anterior devolvería "Número".

Se podría utilizar esta otra SQL para comprobar si el contenido de un campo es un número, aunque es más engorrosa y produce los mismos efectos, incluso puede que se nos haya escapado algún carácter especial en la lista, en cuyo casi daría que es Número, sin serlo:

Código:

select decode(instr(translate(nombre_campo,
    'abcdefghijklmnopqrstuvwxyzñABCDEFGHIJKLMNOPQRSTUVWXYZÑ!¡|"·$%&/()=?¿@#¬*^`Çç_/\<>:;{}',
    'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'),'X'), '0', 'Número', 'No número') Es_Numero
FROM dual
MensajePublicado:
Mar Ago 25, 2009 5:27 am
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » Oracle Database, motor de base de datos profesional  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A