Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   Realizar cálculos en el servidor o no? (https://www.clubdelphi.com/foros/showthread.php?t=95047)

Elias011267 02-02-2021 15:46:54

Realizar cálculos en el servidor o no?
 
Buen dia. Estoy migrando mis aplicaciones en Vfp 9 a Delphi comunity 10.3. El caso es que, anteriormente realizaba las operaciones de la base de datos en el servidor como standard según las reglas clientes - servidor. Mi gestor de base datos es firebird 3.0. Por ejemplo hacer el calculo de prestaciones del sistema de nomina lo hacia en el servidor, pero ahora que programo en delphi veo que tiene muchas funciones que me facilitan la programación, funciones como dayinmonth, dayinayear me ayudan mucho para realizar los calculos (entre otros).
La pregunta es ¿si realizo los cálculos en la aplicación cliente estropeo el diseño cliente servidor?


Gracias

Casimiro Notevi 02-02-2021 17:57:44

Si ya lo hace la BD, mejor.

elrayo76 03-02-2021 01:06:23

Yo diría como Casimiro que sigas como lo tienes, así no tendrás que cambiar mucho (todo lo que migres). Lo nuevo si puedes mejorarlo y ver donde te conviene hacerlo.

Igual mi opinión es que todo lo que se pueda hacer en la base de datos mucho mejor, siempre esta estará en un servidor el cual será por regla mas potente que la computadora cliente.

Ejemplo: si estás leyendo los datos de la base para mandarlos a la aplicación es preferible que los cálculos se hagan en el servidor y mandes todo resuelto.

Si tienes que guardar los datos o actualizarlos, muchas veces se pueden hacer los cálculos en la aplicación, pero hay veces que necesitas datos que están en alguna tabla de la base de datos y para no mandarlos al cliente es recomendable pasar todo a la DB y terminar de calcular ahí.

Saludos,
El Rayo

Neftali [Germán.Estévez] 03-02-2021 08:46:28

Ya han comentado cosas y al final se trata de que no hay "nada" estandard (establecido), todo depende. Entiendo que antes no utilizabas Firebird, por lo tanto todo el diseño es nuevo (Delphi + Firebird).
Dentro de una aplicación Delphi es bueno separar la parte visual de las reglas de negocio, independientemente de que sea diseñada en capas o no.
Utilizar Delphi te da muchas facilidades, para mi por lo tanto no tiene mucho sentido crear toda la lógica de negocio en la Base de Datos. Personalmente dejo eso para los cálculos complejos o especiales.

Elias011267 04-02-2021 15:20:51

Gracias por sus sabias opiniones. Es muy tentador utilizar las funciones de Delphi 10.3 comparado con las de firebird 3.0. Buscare el equilibrio para la mayor efectividad. Tomare en cuenta que la aplicación solo esta en tres pc y todas son tan o mayor potencia que el servidor.

mamcx 04-02-2021 18:25:23

El "depende" de la respuesta se resuelve entendiendo en que capa estas.

Si la logica es de datos/negocios es mejor en el servidor. Esto incluye validaciones (nunca confies que el cliente mande cosas correctas)

Pero si es para la UI, la logica es en el cliente, aunque es mejor "pre-empaquetar" en el servidor.

En concreto:

Una factura, mandas datos:

Código Delphi [-]
Factura
    Enc: ClienteId
    Items: 
       Ref, Qty,
       Ref, Qty

Y devuelves datos correctos y validados:

Código Delphi [-]
Factura
    Enc: ClienteId, TOTAL
    Items: 
       Ref, Qty, TOTAL
       Ref, Qty, TOTAL

En el cliente podrias hacer el TOTAL para mostrar el calculo en realtime, pero el servidor NO puede creerle que le mande el total correcto. Todo eso es en el servidor.

En el cliente haces cosas de presentacion y serializar/deserializar los datos.


La franja horaria es GMT +2. Ahora son las 11:54:51.

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