FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
Muy lento al insertar registro >100.000
Saludos, utilizo Delphi7 con fb1.5
con un ibdataset hago un append, relleno los valores de los campos y después un post, y un commitretainning de la transacción. cuando la tabla tiene pocos registros funciona rápido, pero en tablas con mas de 100.000 regs. va lentísimo, seguramente será algo sencillo, pero no lo veo. No se que mas información dar... Agradecería la ayuda del foro windows xp, pIV a 1.5GHz, 640MbRam. |
#2
|
||||
|
||||
¿Porqué utilizas CommitRetainning el lugar de Commit?
Piensa que esta instrucción es menos eficiente, aunque no dices si llevas "mucho rato" haciendo CommitRetaining cuando "va lento".
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#3
|
|||
|
|||
Gracias Neftali por tu pronta respuesta,
ocurre igual con commit que commitretainning, se trata por ejemplo de una entrada de registros por pantalla, al primer registro que entro, ya va lento. Un saludo |
#4
|
|||
|
|||
Saludos,
he estado parando el programa antes y después de las instrucciones con el ibdataset y la lentitud está en el Post (no tiene eventos afterpost ni beforepost), el append y el commit van como las balas. Gracias |
#5
|
||||
|
||||
¿Puedes dejarnos el script de creación de la tabla para que hagamos pruebas?, ¿puedes poner el código delphi de cómo lo haces?, así será más facil que se te pueda ayudar
|
#6
|
|||
|
|||
Gracias por anticipado, aqui teneis:
hago APPEND asigno los valores de T, TIP, NUM igualando de otras variables el resto de los campos vienen de DBEDITs hago POST (aquí es donde va lento) tiene 125.000 regs /**** Generated by IBExpert 13/07/2005 20:33:56 ****/ SET SQL DIALECT 3; SET NAMES NONE; CREATE TABLE ALMACEN ( T SMALLINT, TIP VARCHAR(1), NUM INTEGER, FEC DATE, HOR TIME, ART VARCHAR(11), DES VARCHAR(50), CLI INTEGER, CAN NUMERIC(5,2), CANB NUMERIC(5,2), PRE NUMERIC(5,3), ALB INTEGER, AUT INTEGER ); /**** Indices ****/ CREATE UNIQUE INDEX ALMACEN_IDX1 ON ALMACEN (T, TIP, NUM); |
#7
|
||||
|
||||
Es probable que la tabla tenga triggers que sean los que relentizan el sistema. Para comprobarlo, desactivá los triggers asociados y cronometrá nuevamente.
Es probable también que haya una relación que no esté soportada con un índice. Interbase/Firebird crea automáticamente los índices necesarios cuando declaras un foreign key, pero recuerdo que es posible borrar estos, lo que obliga al sistema a hacer un full scan de la tabla cada vez que se comprueba la integridad. Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#8
|
|||
|
|||
Gracias de nuevo,
no hay triggers, ni eventos after before ni nada que no haya expuesto, es esa tabla asi de sencilla, con Ibexpert me crea los registros de inmediato, pero desde delphi tarda 9 seg., he probado con Fibplus y lo mismo. Pienso que la database está bien configurada, porque ibexpert trabaja bien, creo que el delphi será el culpable, no se... Gracias por vuestro interés. Un saludo |
Herramientas | Buscar en Tema |
Desplegado | |
|
|
|