Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
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 - Acceso a Oracle 10g desde Delphi 6 con ODBC error EInvalidOp
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Acceso a Oracle 10g desde Delphi 6 con ODBC error EInvalidOp

Publicar nuevo tema Responder al tema
Foros de discusión » Borland Delphi, Codegear Delphi .Net   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Acceso a Oracle 10g desde Delphi 6 con ODBC error EInvalidOp Responder citando

Tengo una aplicación desarrollada en Borland Delphi 6 de facturación, contabilidad y recursos humanos. Como motor de base de datos usaba Oracle 9i, la aplicación se conectaba a Oracle mediante el componente gratuito NCOCI:

http://www.ajpdsoft.com/modules.php?name=News&file=article&sid=224#NCOCI8

Que se conecta de forma nativa a Oracle, sin usar ODBC ni BDE. La aplicación funcionaba perfectamente con Oracle 9i.

Pero por necesidades de la empresa he tenido que migrar la versión de Oracle de la 9i a la 10g.

Los componentes NCOCI sólo soportan hasta Oracle 9 y no van con el 10g. He buscado y ahora son de pago y con la crisis no hay presupuesto para adquirir una licencia.

Por ello he cambiado la conexión a Oracle y en vez de usar NCOCI uso ODBC y BDE, como indica este manual:

http://www.ajpdsoft.com/modules.php?name=News&file=article&sid=132

He creado las correspondientes TTable, TQuery, etc. del propio Delphi enlazadas con ODBC.

Casi todo me funciona bien, las consultas, incluso las inserciones. Pero tengo una inserción concreta que no me funciona bien, me da el error:


---------------------------
Debugger Exception Notification
---------------------------
Project gestionCMS.exe raised exception class EInvalidOp with message 'Operación de coma flotante no válida'. Process stopped. Use Step or Run to continue.
---------------------------
OK Help
---------------------------


El código fuente que uso para la inserción de un registro en una tabla de Oracle:

Código:

procedure TformMenuPrincipal.insertarFactura (
    codigo : string; observacion : string; concepto : string);
var
  tipo : string;
begin
  tcInsertar.Close;
  tcInsertar.SQL.Clear;
  tcInsertar.SQL.Add('INSERT INTO FACTURA (CODIGO, OBSERVACION, CONCEPTO, FECHA');
  tcInsertar.SQL.Add(') VALUES (');
  tcInsertar.SQL.Add('to_number(:pDCODIGO), :pOBSERVACION, :pCONCEPTO, :pFECHA');
  tcInsertar.SQL.Add(')');

  tcInsertar.ParamByName('pDBOID').DataType := ftString;
  tcInsertar.ParamByName('pDBOID').AsString := codigo;

  //quitamos caracteres innecesarios
  tipo := trim(reemplazarTexto(tTablatipo.AsString, '(gene', ''));
  tipo := trim(reemplazarTexto(tipo, '(IT', ''));

  tcInsertar.ParamByName('pTIPO').DataType := ftString;
  tcInsertar.ParamByName('pTIPO').Value := tipo;

  tcInsertar.ParamByName('pFECHA').DataType := ftDate;
  tcInsertar.ParamByName('pFECHA').Value :=
      StrToDate (trim(tTablafecha.AsString));

  tcInsertar.ParamByName('pOBSRVACION').DataType := ftString;
  tcInsertar.ParamByName('pOBSERVACION').Value := observacion;

  tcInsertar.ParamByName('pCONCEPTO').DataType := ftString;
  tcInsertar.ParamByName('pCONCEPTO').Value := concepto;

  tcInsertar.ExecSQL;
end;


¿Cual puede ser el problema? ¿el to_number?
MensajePublicado:
Mie Dic 22, 2010 7:58 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Acceso a Oracle 10g desde Delphi 6 con ODBC error EInval Responder citando



Anuncios



varios escribió:
Tengo una aplicación desarrollada en Borland Delphi 6 de facturación, contabilidad y recursos humanos. Como motor de base de datos usaba Oracle 9i, la aplicación se conectaba a Oracle mediante el componente gratuito NCOCI:

http://www.ajpdsoft.com/modules.php?name=News&file=article&sid=224#NCOCI8

Que se conecta de forma nativa a Oracle, sin usar ODBC ni BDE. La aplicación funcionaba perfectamente con Oracle 9i.

Pero por necesidades de la empresa he tenido que migrar la versión de Oracle de la 9i a la 10g.

Los componentes NCOCI sólo soportan hasta Oracle 9 y no van con el 10g. He buscado y ahora son de pago y con la crisis no hay presupuesto para adquirir una licencia.

Por ello he cambiado la conexión a Oracle y en vez de usar NCOCI uso ODBC y BDE, como indica este manual:

http://www.ajpdsoft.com/modules.php?name=News&file=article&sid=132

He creado las correspondientes TTable, TQu...


¿Qué tipo de datos tiene cada campo de la tabla de Oracle?
MensajePublicado:
Mie Dic 22, 2010 7:04 pm
Top of PageVer perfil de usuario
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Re: Acceso a Oracle 10g desde Delphi 6 con ODBC error EInval Responder citando



Anuncios



alonsojpd escribió:
¿Qué tipo de datos tiene cada campo de la tabla de Oracle?


CODIGO -> NUMBER
OBSERVACION -> VARCHAR
CONCEPTO -> VARCHAR
FECHA -> DATE
MensajePublicado:
Mie Dic 22, 2010 7:07 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Acceso a Oracle 10g desde Delphi 6 con ODBC error EInval Responder citando



Anuncios



varios escribió:
CODIGO -> NUMBER
OBSERVACION -> VARCHAR
CONCEPTO -> VARCHAR
FECHA -> DATE


El problema, posiblemente, lo tienes en la líneas de código fuente:

Código:

  tcInsertar.ParamByName('pFECHA').DataType := ftDate;
  tcInsertar.ParamByName('pFECHA').Value :=
      StrToDate (trim(tTablafecha.AsString));


Para Oracle, el tipo de datos DATE almacena fecha y hora, por lo que, para que no te dé el error deberías cambiar las líneas anteriores por:

Código:

  tcInsertar.ParamByName('pFECHA').DataType := ftDateTime;
  tcInsertar.ParamByName('pFECHA').Value :=
      StrToDateTime (trim(tTablafecha.AsString));
MensajePublicado:
Jue Dic 23, 2010 11:45 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 » Borland Delphi, Codegear Delphi .Net  

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