FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
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 |
#2
|
||||
|
||||
Si ya lo hace la BD, mejor.
|
#3
|
|||
|
|||
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
__________________
Si tienes una función o procedimiento con diez parámetros, probablemente hayas olvidado uno Última edición por Neftali [Germán.Estévez] fecha: 03-02-2021 a las 08:37:06. |
#4
|
||||
|
||||
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.
__________________
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. |
#5
|
|||
|
|||
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.
|
#6
|
||||
|
||||
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:
Y devuelves datos correctos y validados:
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.
__________________
El malabarista. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Realizar calculos y buscar número mayor en DBGrid | lujurock | Conexión con bases de datos | 14 | 12-11-2008 11:05:17 |
tipo de dato para realizar calculos?? | Leogiro | OOP | 1 | 16-09-2004 02:10:15 |
Calculos | Aleca | OOP | 2 | 18-08-2004 18:31:43 |
quiero realizar unos calculos | pharaonhx | Tablas planas | 4 | 20-03-2004 02:12:11 |
Como realizar una aplicacion cliente/servidor en interbase? | Argaron | Firebird e Interbase | 2 | 16-05-2003 20:17:50 |
|