PDA

Ver la Versión Completa : Conexion sql Primero bien despues Lenta


juank1971
12-08-2008, 21:30:23
Saludos:
Llevo tiempo mirando sus respuestas y preguntas y nunca he preguntado nada, me disculpan si no es el lugar correcto y me corrigen,
tengo una aplicacion con base de dato SQL Server 2000 y las tablas esan creciendo pero hago calculos con todos los registros, digamos, cuentas por cobrar o pagar de todas las unidades y una tabla con el el envio de dichos datos de cada unidad. primero bien , pero ya las unidades crecieron y demora la muestra cda ves mas.

Uso TadoConexion y TadoTable, TadoQuery no lo uso pues en las tablas esta lo indispensable de cada unidad y necesito sumar digamos todos los importes de todas las unidades, no edito nada solo muestro totales en diversas formas pero generalemte con todos los datos

me ayudan con la lentitud ????? es codegear 2007

coso
12-08-2008, 21:37:40
hola, ¿como sumas? ¿haciendo 'select sum(...) as suma ' o bien recorriendo cada registro?

si no es el caso que usas sum :


q.active := false;
q.SQL.Text := 'select sum(importe) as suma_importes from tabla';
q.active := true;
showmessage(FormatFloat('0.00',q.FieldByName('suma_importes').Asfloat));


a ver si te va mas rapido.

Tambien puedes usar query.DisableControls, query.enablecontrols, para optimizar un poco mas, antes de los calculos

juank1971
12-08-2008, 21:54:04
gracias
Cada dia me gusta mas el delphi ....

No dije antes que uso DevExpress los Pivot y quantum grid se suma solos los totales, no tengo que escribir codigo, antes lo hacia bien pero ya estan lentos, probe en grid solos del delphi y esta lenta la carga de los Tadotable. use MemData y crece memoria.

Pregunto tienes otra solucion ???? se pueden usar DevExpress por capas ?? en sql ??? que se yo ...no se.... no puede ser que tenga la cima de la belleza de la aplicacion terminada y el delphi no me de lo que quiero que tanto ha hecho por mi durante tanto
tiempo.

coso
12-08-2008, 21:57:30
ah, pues ni idea

juank1971
12-08-2008, 22:06:30
de todas formas mientras el palo va y biene diganme please, que evento puedo utilizar para poner un progress bar en la carga de TAdoTable,para por lo menos si no resuelvo el problema de la lentitud mostrar el progreso de la carga de las tablas hacia los PivotGrids y los QuantumGrid, he probado eventos de el TAdoConnection y nada, probe el FetChProgress de los TadoTable y no pincha tampoco, no entra a ese evento mientras se carga, no veo ningun evento significativo en el Datasorce tampoco.

Pregunta,... me pueden decir donde se puede meter codigo para aumentar un progress en la carga de TAdoTable, son varios de ellos y se demora un poco....

juank1971
12-08-2008, 22:11:59
Ya me tengo que ir, de aqui , mañana regreso, estoy seguro que esta noche sueño que me responden y temprano tengo algo que agregar a mi aplicacion

gracias a todos y a ti coso que se que en esto el tiempo es oro

salud y pesetas..................:)

ContraVeneno
12-08-2008, 23:30:47
Si usas TTable, al principio no era lenta porque eran pocos registros, pero al ir aumentando, aumenta la carga de datos y si utilizas la QuamtumGrid con la opción "LoadAllRecords" en verdadero, se ira tardando cada vez más conforme aumenten los registros.

Lo mejor sería empezar a utilizar TQuery en lugar de Ttable y seleccionar solo los registros que sean necesarios (en lugar de toda la tabla).

Neftali [Germán.Estévez]
13-08-2008, 10:26:07
Vamos a ver; Has dicho muchas cosas, de forma poco desordenada (perdona que te lo diga) y veo que vas dando palos de ciego y se si sabes realmente lo que estás haciendo (esa es la sensación que tengo).
Te propongo algunas cuestiones; Tal vez algunas ya las tienes claras, de todas formas te lo comento.

No soin todas excluyentes, tal vez puedas combinar unas con otras.

(1) SQL Server: Ya que utilizas SQL Server aprovecha las características que este te brinda. Revisa los planes de ejecución de las consultas. Revisa si puedes añadir índices por algun campo.
Por último puedes hacer alguna prueba con Stored Procedures, sobre todo para el tema de cálculo de totales.

(2) QuantumGrid de DevExpress: Todos sabemos que las QuantumGrid son excelentes, pero no hacen milagros. Los Grids de la Quantum permiten Agrupaciones, calcular totales, filtrar columnas por los títulos, ordenar,....(**) y mucho más, pero eso tiene un precio grande; Deben cargar todos los datos en memoria. En la configuración del Grid, puedes cambiar este comportamiento (en la parte donde se configura el DataSource), pero al cambiar el modo de carga para que no cargue TODOS los registros en memoria (como lo hace un DbGrid estandard con cursor clServerSide) pierdes todas esas mejoras.
==> por lo tanto debes tener claro cuando puedes usar los Grids de las Quantum. Si necesitas todos esos añadidos (**) debes trabajar con tablas pequeñas, porque a medida que las tablas van creciendo el tema se va a hacer muy lennnnnto.

(3) Cargar Datos o Totales: Debes tener claro qué necesitas. Pero hay una cosa clara, si lo quieres TODO, no va a ser rápido. Por un lado tenes los datos y por otro los totales o cálculos. Hay dos opciones:

(a) Cargar todos los datos y calcular totales en memoria (para eso ya tienes la Quantum).
(b) No cargar todos los datos, pero entonces los totales deberás calcularlos tú utilizando SQL (SELECT, COUNT, MAX, SUM, GROUP BY,...) o Stored Procedures.

(4) Optimizaciones: Una vez tengas claro lo que vas a necesitar puedes intentar realizar optimizaciones, aunque estas dependerán de la solución escogida. Si finalmente optas por cargar todos los datos(yo no lo haría), puedes revisar las tablas temporales de SQL Server que funcionan bastante bien (mejor en las últimas versiones); También puedes usar Stored Procedures o incluso funciones para obtener los datos que necesitas, si es que necesitas consultas muy complejas y minimizar así el tráfico de datos por la red.
Acostumbrate a utilizar Filtros (y a obligar a los usuarios a que los utilicen) antes de enviar las consultas, y no que filtren cuando los datos ya han llegado al cliente a través de la red.

Hay muchas cosas ha realizar, aunque debes tener sentido común y minimizar los datos con los que trabajas. Utilizar o traer sólo los que necesitas.

NOTA: Piensa que tal como lo dejes ahora (en cuanto a lentitud), dentro de 5 meses va a ir muuuuucho peor.

Un saludo. ;)

coso
13-08-2008, 12:28:06
sigo pensando que haciendo esto:


q.active := false;
q.SQL.Text := 'select sum(importe) as suma_importes from tabla';
q.active := true;
showmessage(FormatFloat('0.00',q.FieldByName('suma_importes').Asfloat));


arreglado. A mi me suma mas o menos 15.000 registros en menos de 1 segundo

coso
13-08-2008, 12:30:00
salud y pesetas..................:) jejejejejej, claro como soy de Girona jejjejjjejj :D:D:D:D:D:D

juank1971
13-08-2008, 14:59:17
Gracias a todos por su tiempo

Ta claro no existe magia que a veces uno quiere que le saquen de debajo de la manga una idea genial y que todo salga a pedir de boca, evidentemente la cantidad de records es directamente proporcional a la velocidad y pierdes velocidad o gastas recursos de memoria gigante en la estacion cliente.

todo lo que me comentan es muy util, aunque ya a estas alturas de la aplicacin estoy frito en manteca de pescao, ya eso esta corriendo hace rato.
aunque estuve calculando algunas cosas y las bases de datos no van a crecer ilimitadamente porque los registros se sobreescriben cada una fecha. o sea la lentitud es un poco, pero no aumenta, por ahora las estaciones clientes tienen suficiente memoria y trabajan aceptablemente, solo me queda señalizar en un progress de una splash form la carga de las diferentes tablas.

En cuanto a lo de aprovechar lo de sql ta clarisimo, lo que me deje llevar por la emosionante funcionalidad de los devexpress, y los totales no los controlo yo , lo hacen los clinentes segun el agrupamiento que hagan por supuesto teniendo delante todos los datos. tendria que ponerme a validar segun el ordenamiento y agrupamiento hacer las Querys pertinentes.

En fin resuelvo por el momento con incrementar un barprogress mientras cargan las tablas....
gracias a todos...............:D

Neftali [Germán.Estévez]
13-08-2008, 15:18:42
A mi me suma mas o menos 15.000 registros en menos de 1 segundo

Creo que el problema no está en los totales, ya que una vez están los datos en memoria, calcular los totales no implica casi tiempo; Creo que el problema está en que los DevExpress deben cargar todos los datos para poder calcularlos.
Por tanto, haciendo lo que tu comentas no servirá de nada, si luego se cargan todos los datos.

juank1971
13-08-2008, 16:00:01
ta claro...............


y mi progress bar ???? en que evento de que objeto de que clase se puede incrementar mientras se cargan los datos ???

coso
13-08-2008, 16:14:55
si tienes por alla algun datasource, en el ondatachange mismo, eso si, tendras que diferenciar por codigo cuando se estan cargando los datos, y cuando se esta, por ejemplo, simplemente haciendo un scroll. No se bien bien como va el DevExpress ni el QuantumGrid, pero si proviene de TCustomDBGrid, tendra la propiedad datasource con su evento onchange correspondiente

juank1971
13-08-2008, 18:02:04
El OnDataChange del DataSource no me funcionó para lo que quiero, lo probé en la carga de los datos y entra a ese evento la traza solamente una vez durante la carga de los datos, creo que cuando finaliza, no me sirve, necesito un evento de algo que me diga un porciento de la carga de datos desde el SQL a la estación cliente para yo poder actualizar el progress y mostrarle al cliente lo que mas o menos le queda por esperar para que se le abra la aplicacion.

gracias de todas .......