Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 02-02-2021
Elias011267 Elias011267 is offline
Miembro
 
Registrado: jul 2020
Posts: 73
Poder: 4
Elias011267 Va por buen camino
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
Responder Con Cita
  #2  
Antiguo 02-02-2021
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.043
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Si ya lo hace la BD, mejor.
Responder Con Cita
  #3  
Antiguo 03-02-2021
elrayo76 elrayo76 is offline
Miembro
 
Registrado: ene 2004
Ubicación: En la tierra, por eso mis archivos en la tierra y no en la nuebe...
Posts: 290
Poder: 21
elrayo76 Va por buen camino
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.
Responder Con Cita
  #4  
Antiguo 03-02-2021
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.285
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
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.
Responder Con Cita
  #5  
Antiguo 04-02-2021
Elias011267 Elias011267 is offline
Miembro
 
Registrado: jul 2020
Posts: 73
Poder: 4
Elias011267 Va por buen camino
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.
Responder Con Cita
  #6  
Antiguo 04-02-2021
Avatar de mamcx
mamcx mamcx is offline
Moderador
 
Registrado: sep 2004
Ubicación: Medellín - Colombia
Posts: 3.911
Poder: 25
mamcx Tiene un aura espectacularmamcx Tiene un aura espectacularmamcx Tiene un aura espectacular
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.
__________________
El malabarista.
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

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


La franja horaria es GMT +2. Ahora son las 01:57:07.


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