FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
Comenzando con DBX
Hola a todos, hasta ahora siempre he utilizado los componentes BDE para acceder a datos y estoy empezando a probar con DBX, y ando un poco perdido.
La primera prueba que he realizado ha sido rellenar un DBGrid con los datos de una tabla, comparando velocidades entre BDE y DBX, y resulta que con un TTable (BDE) Obtengo todos los datos en 0,6 segundos. y con un clientDataSet 26 segundos. Utilizo la misma tabla de la misma base de datos en SQL Server 2008. Yo tenia entendido que DBX era mas rapido, ¿Que puedo estar haciendo mal?. Gracias por anticipado. |
#2
|
||||
|
||||
Bienvenido a clubdelphi, ¿ya leiste nuestra guía de estilo?, gracias por tu colaboración
Cita:
Y recuerda poner títulos descriptivos a tus preguntas, "Comenzando con DBX" no describe lo que preguntas. De todas formas te anticipo que, efectivamentte, DBX es bastante rápido. |
#3
|
|||
|
|||
Gracias Casimiro por tu repuesta.
Lo que hago es conectar un un Dbgrid a una tabla de SQL Server 2008, esta tabla tiene unos 120.000 registros. La conecto a traves de un TTable , TDatabase y un TDataSource, y en el onClick de un TButton pongo "TTable.Active:=True;" de esta manera veo los datos en menos de un segundo. Despues realizo la misma operación pero utilizando un TSQLConnection,TSQLTable,DataSetProvider,ClientDataSet y en el evento on Click del TButton "ClientDataSet.Active:=True;" pero esta vez tarda entre 20 y 26 segundos en aparecer los datos. Todo se encuentra en el mismo ordenador, por ahora son pruebas y las realizo en local. No se que puedo estar haciendo mal, pues no creo que pueda haber esa diferencia de velocidad. Gracias. |
#4
|
||||
|
||||
¿Pero para qué quieres 120000 registros en una tabla?, ¿los vas a leer todos?
|
#5
|
||||
|
||||
Hace muchos años que no manejo el obsoleto BDE pero, por la diferencia de tiempos que Gherardo señala, es casi seguro que TTable no esté trayendo esos 120 mil registros "de un jalón", es decir, que probablemente está haciendo "paginación" (se trae un grupo de registros y luego el siguiente según se necesiten).
Para salir de dudas, Gherardo, coloca una instrucción "Tabla.Last" después de poner en True su propiedad Active. En ese caso TTable habrá de demorar algo más. Con TClientDataSet también pueden traerse registros en paquetes de n filas según vaya necesitando avanzar el cursor (propiedad PacketRecords). No obstante, prefiero traerme de un solo golpe todos los registros de la consulta (dejando PacketRecords en -1), dado que no es muy buena práctica "entretener" al servidor con impredecibles acciones de la interfaz de usuario. Y bueno, si realmente se necesita una consulta de 120 mil registros, debemos acostumbrarnos a que algo así no es gratis (al menos no con los equipos actuales). |
#6
|
|||
|
|||
Muchas gracias AL Gonzalez.
Una vez que tienes todos los registros "aquì", el Last es instantaneo en ambos casos. Si cambio la propiedad PackectRecords del ClientDataSet a un valor distinto a -1, en este caso si hay retardo en el Last del clientDataSet, esto no me preocupa, pero me da un error al realizar un ApplyUpdate. El error dice lo siguiente: " no se puede crear una nueva transacción, se excedio la capacidad ". Gracias. |
#7
|
||||
|
||||
Al final de cuentas, el punto clave aqui amigo Gherardo es lo que pregunta Casimiro:
Cita:
Te aconsejo replantear tu modelo, de manera tal que el usuario proporcione un filtro a la consulta, o que utilices un esquema de paginación... no se... BDE es una tecnología que en su momento fue la respuesta a muchos problemas, pero hace años que no tiene soporte, por lo cual urge que te salgas de ahí... si quieres un futuro para tu sistema. Cuando pienses en BDE, piensa en el equivalente de estar instalando a tu usuario el sistema operativo Windows 95... A medida que vayas entrando en DBX vas a encontrar sus bondades... Un saludo, |
#8
|
||||
|
||||
Cita:
// Saludos |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Comenzando con Firebird... | Kenobi | SQL | 6 | 15-04-2007 19:44:42 |
Comenzando de Nuevo con Delphi 2007 | dvd2000 | Conexión con bases de datos | 3 | 15-04-2007 15:54:40 |
|