![]() |
![]() |
![]() |
![]() |
![]() |
FTP | ![]() |
![]() |
CCD | ![]() |
![]() |
Buscar | ![]() |
![]() |
Trucos | ![]() |
![]() |
Trabajo | ![]() |
![]() |
Foros | ![]() |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
Ambas tablas están dentro de la misma base de datos? si es así porque no lanzas un StoreProcedure que realice un insert de los datos desde delphi por cada registro dentro de un try..except..end para que si te devuelve un error al menos siga adelante y puedas tener referencia del mismo.
Ej.: Código:
while not tabla.eof do begin try with sp_actualiza do begin parambyname('codigo').Value = x; parambyname.... prepare; execproc; close; end; except on e: exception do begin memo1.lines.add('Registro no actulizado con Código :'+x') memo1.lines.add(' *** '+e.message); end; end; tabla.next; end; Espero que te sirva de orientación. Saludos Última edición por jjoliveras fecha: 19-04-2004 a las 18:09:08. |
#2
|
||||
|
||||
Hola.
¿ Hay alguna razón para los CommitRetaining ?. Una serie larga de Soft Commit sin un Hard Commit que pueda liberar el contexto de la transacción, va a degradar el rendimiento del Servidor. Simplemente quita el CommitRetaining, no parece que lo necesites para nada. Respecto al Locate, tampoco conozco la implementación de los IBX, aunque creo haber leído que efectivamente recorre todos los registros. Así que parece mejor solución lanzar una consulta en el Servidor, como comentaba juachgate. Aunque indudablemente, la mejor solución, en caso de ser posible, es realizar todo el proceso de búsqueda y inserción dentro de un procedimiento almacenado, como comenta jjoliveras. Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no). |
#3
|
|||
|
|||
ahora estamos mejorando...
saque los locate, deje el commitretailn..., en los ibxdataset puese Forcedrefresh := False, sace un Fetchall que estaba en el medio y la cosa mejoro bastante ahora por lo menos es constante la velocidad de insercion en todos los registros. No obstante sigue siendo lento. Calculo quedebe ser por los IBX, probare cambiarlos y ver que pasa. No obstante. Creo que puede verse degradada la velocidad en general ya que la transferencia la hago desde un Btrieve (con ODBC) mas un monton de cuentas, etc, etc. Vere si puedo mejorar algo. Si tienen alguna idea, desde ya gracias. |
#4
|
||||
|
||||
Cita:
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no). |
#5
|
|||
|
|||
le encontre la vuelta...
la idea es no utilizar para nada el locate... se pone lentisimo y es en progresion geometrica. por lo que calculo que el locate realiza la busqueda por toda la tabla. Ademas utlizo el commit todo el proceso y no para cada insercion. Esto no afecta mucho el rendimiento pero hace unos segundo mas rapido todo. Voy a probar con algunos componente que no sean lo IBA y les comento que paso. Gracias por todo. |
![]() |
|
|
![]() |
|