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 13-07-2005
pjjorda pjjorda is offline
Miembro
 
Registrado: jul 2005
Posts: 34
Poder: 0
pjjorda Va por buen camino
Smile 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.
Responder Con Cita
  #2  
Antiguo 13-07-2005
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.293
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
¿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.
Responder Con Cita
  #3  
Antiguo 13-07-2005
pjjorda pjjorda is offline
Miembro
 
Registrado: jul 2005
Posts: 34
Poder: 0
pjjorda Va por buen camino
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
Responder Con Cita
  #4  
Antiguo 13-07-2005
pjjorda pjjorda is offline
Miembro
 
Registrado: jul 2005
Posts: 34
Poder: 0
pjjorda Va por buen camino
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
Responder Con Cita
  #5  
Antiguo 13-07-2005
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.057
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
¿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
Responder Con Cita
  #6  
Antiguo 13-07-2005
pjjorda pjjorda is offline
Miembro
 
Registrado: jul 2005
Posts: 34
Poder: 0
pjjorda Va por buen camino
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);
Responder Con Cita
  #7  
Antiguo 13-07-2005
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
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
Responder Con Cita
  #8  
Antiguo 14-07-2005
pjjorda pjjorda is offline
Miembro
 
Registrado: jul 2005
Posts: 34
Poder: 0
pjjorda Va por buen camino
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
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


La franja horaria es GMT +2. Ahora son las 14:01:04.


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