Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 25-04-2012
Avatar de JoseAntonio
JoseAntonio JoseAntonio is offline
Miembro
 
Registrado: abr 2006
Ubicación: Lima - Ciudad de los Reyes.
Posts: 87
Poder: 19
JoseAntonio Va por buen camino
malas practicas?

Tipico que tienes tus componentes de datos persistentes, es decir todos tus datasets y querys los llenas en tiempo de diseño, eso tiene sus limites en sistemas medianamente complejos, en donde cuando haces un pequeño cambio en las tablas (todo cambio es posible incluso en la data) tienes que volver a cambiar todo en tus componentes de dato en tiempo de diseño y ademas te llenas de datasets y querys en tu modulo de datos que ya no sabes como manejarlo. Solucion para esto: usa componentes de datos (datasets y querys) dinamicos que se llenen (y liberen) en tiempo de ejecucion, para eso tienes que programar todo explicitamente en el codigo, de otro modo ni tu ni nadie podra manejar tanto embrollo. Salu2.
__________________
nuestro carácter está reflejado en cada línea de código que escribimos.
Responder Con Cita
  #2  
Antiguo 25-04-2012
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por mcbullrich Ver Mensaje
Ya lo dije, quiero poner por ejemplo algún tipo de groupbox para meter adentro la tabla master y todas las nested de un objeto incluyendo el TQLquery, TProvider, TClientDataset y TDatasource y TImages si las tuviese. Y así para otros objetos persistentes en mi base, cada grupo con un color...
De esta manera puedo hacer más entendible mi DataModule.
Podría Poner un Group para los componentes de conexión. Los Popup menus en otro corralito, los action managers en otro. Y así podría de paso desarrollar mi parte artística...
Cita:
Empezado por JoseAntonio Ver Mensaje
Tipico que tienes tus componentes de datos persistentes, es decir todos tus datasets y querys los llenas en tiempo de diseño, eso tiene sus limites en sistemas medianamente complejos, en donde cuando haces un pequeño cambio en las tablas (todo cambio es posible incluso en la data) tienes que volver a cambiar todo en tus componentes de dato en tiempo de diseño y ademas te llenas de datasets y querys en tu modulo de datos que ya no sabes como manejarlo. Solucion para esto: usa componentes de datos (datasets y querys) dinamicos que se llenen (y liberen) en tiempo de ejecucion, para eso tienes que programar todo explicitamente en el codigo, de otro modo ni tu ni nadie podra manejar tanto embrollo. Salu2.
Soluciones terribles ambas.


Lo que tienes que hacer no es "embellecer" tus datamodules, que no siendo componentes visuales no pueden embellecerse. Lo que tienes que hacer es aprender a organizar tu código. Usa varios datamodules, tantos como sean necesarios y sin mezclar elementos que no tienen relación. PopupMenus en un datamodule, actionmanagers en otros y datasets en otro. Y cada grupo puede subdividirse en varios datamodules según convenga a tu modelo, por ejemplo, un módulo para ventas, otro para almacen, otro para clientes, etc.

Por otra parte, los datasource los considero mejor en los formularios que los usen y no en el datamodule.

Y, finalmente,

Cita:
Empezado por mcbullrich Ver Mensaje
Bueno, haga un esfuerzo por entender..
Quien tiene que hacer un esfuerzo es el que pregunta, los foros no son un servico técnico.

// Saludos
Responder Con Cita
  #3  
Antiguo 25-04-2012
Avatar de AzidRain
[AzidRain] AzidRain is offline
Miembro Premium
 
Registrado: sep 2005
Ubicación: Córdoba, Veracruz, México
Posts: 2.914
Poder: 21
AzidRain Va camino a la fama
Y añadiendo a lo que dice Roman, tambien puedes meter los datasets que se utilizan solo en un formulario dentro del mismo, aunque parece algo "poco elegante", sin embargo considero que un datamodule debe contener componentes que pueden estar accesibles a mas de un formulario o proceso dentro de tu programa. Pero bueno ya es cuestión del estilo de cada quien.

Por otro lado eso de "embellecer" no tiene caso pues ya Delphi trae el Explorador de Código que permite ver los componentes del datamodule en forma ordenada por clase y alfabeticamente que creo que es más que suficiente cuando se tienen muchos componentes metidos ahí.
__________________
AKA "El animalito" ||Cordobés a mucha honra||
Responder Con Cita
  #4  
Antiguo 25-04-2012
cloayza cloayza is offline
Miembro
 
Registrado: may 2003
Ubicación: San Pedro de la Paz, Chile
Posts: 914
Poder: 23
cloayza Tiene un aura espectacularcloayza Tiene un aura espectacular
Si quieres poner TGroupbox, colores, etc. en vez de TDatamodule...

Usa un TForm en vez de TDatamodule..

Saludos
Responder Con Cita
  #5  
Antiguo 26-04-2012
ASAPLTDA ASAPLTDA is offline
Miembro
 
Registrado: jun 2003
Ubicación: COLOMBIA-CALI
Posts: 639
Poder: 21
ASAPLTDA Va por buen camino
Smile

Cita:
Empezado por JoseAntonio Ver Mensaje
Tipico que tienes tus componentes.. Solucion para esto: usa componentes de datos (datasets y querys) dinamicos que se llenen (y liberen) en tiempo de ejecucion, para eso tienes que programar todo explicitamente en el codigo, de otro modo ni tu ni nadie podra manejar tanto embrollo. Salu2.
Hola Podrias compartir un ejemplo basico para ver como funciona
Responder Con Cita
  #6  
Antiguo 26-04-2012
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 30
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Lo siguiente es un esquema, a grandes rasgos, de cómo organizo estos componentes con Magia Data. Los recuadros en rojo indican algunas de las muchas características que le dan valor a este paquete de componentes. No me salvo de tener módulos de datos bastante grandes, pero consigo que sean un poco más fáciles de manejar.

Módulo de datos dmServidor:


Módulo de datos dmProveedor:


Módulo de datos dmCliente:


Formulario de captura:


Este enlace también puede ser de ayuda.

OJO: En Delphi, no necesariamente hay que emplear dbExpress (TSQLConnection, TSQLQuery...) para poder aprovechar la potencia de los conjuntos de datos clientes (TClientDataSet). Los colegas suelen pensar que dbExpress y MIDAS son parte de lo mismo; sí que combinan bien pero no están casados. Por otro lado, TMagiaDataSetProvider y TMagiaDataSource pueden trabajar con cualquiera de las muchas clases data sets existentes (ADO, ZeosLib, etcétera), puesto que sus clases padres (TDataSetProvider y TDataSource) también.

Saludos cordiales.

Al González.
Responder Con Cita
  #7  
Antiguo 26-04-2012
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por Al González Ver Mensaje
Lo siguiente es un esquema, a grandes rasgos, de cómo organizo estos componentes con Magia Data.
Disculpa Al, pero no entiendo. Veo que usas distintos datamodules, como otros hemos expresado, pero no entiendo qué papel desempeñan las propieades que marcas en la organización de los componentes.

Será que ando espeso

// Saludos
Responder Con Cita
  #8  
Antiguo 26-04-2012
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola.

Y yo sigo insistiendo que no le encuentro sentido a "embellecer" algo que no se podrá ver...

Saludos.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....

Última edición por ecfisa fecha: 26-04-2012 a las 17:50:40.
Responder Con Cita
  #9  
Antiguo 26-04-2012
mcbullrich mcbullrich is offline
Registrado
NULL
 
Registrado: oct 2011
Posts: 8
Poder: 0
mcbullrich Va por buen camino
Aclaración sobre el término "embellecer"

Primero quiero volver a decir que no lo inventé yo. Lo tomé prestado de los utilitarios llamados "code beautifiers", aunque estos solo se meten con el código. Por extensión lo intento aplicar a la cuestión de diseño visual. Por otro lado entiendo que la la belleza podría no ser el mejor término en estos casos, llamemoslo si se quiere herramientas de ayuda de diseño visual. Por ejemplo: Un diagrama gráfico de entidad-relación o un diseñador visual de objetos no agrega nada a la efectividad del código, pero creo que son buenas prácticas para cuando un diseño quiere ser compartido en un equipo de trabajo. La verdad es que a veces pierdo mucho tiempo buscando una tablita en un datamodule y a veces no recuerdo bien como se engancha con otras tablas.

Y sigamos discutiendo nomás, que cada uno va rescatando un poco de cada post.

Y además tenía un problema de servicio técnico:
Tengo una heladera Siam de año 63. Donde puedo conseguir el termostato original? Le puedo adaptar algún otro? Y si la conecto directo? Y si me resigno a tomar la coca caliente?
En fin, se que quizás este no es el foro adecuado...
Responder Con Cita
  #10  
Antiguo 26-04-2012
[egostar] egostar is offline
Registrado
 
Registrado: feb 2006
Posts: 6.557
Poder: 25
egostar Va camino a la fama
Cita:
Empezado por mcbullrich Ver Mensaje
Aclaración sobre el término "embellecer"

Primero quiero volver a decir que no lo inventé yo. Lo tomé prestado de los utilitarios llamados "code beautifiers", aunque estos solo se meten con el código. Por extensión lo intento aplicar a la cuestión de diseño visual. Por otro lado entiendo que la la belleza podría no ser el mejor término en estos casos, llamemoslo si se quiere herramientas de ayuda de diseño visual. Por ejemplo: Un diagrama gráfico de entidad-relación o un diseñador visual de objetos no agrega nada a la efectividad del código, pero creo que son buenas prácticas para cuando un diseño quiere ser compartido en un equipo de trabajo. La verdad es que a veces pierdo mucho tiempo buscando una tablita en un datamodule y a veces no recuerdo bien como se engancha con otras tablas.

Y sigamos discutiendo nomás, que cada uno va rescatando un poco de cada post.
Y no habrá sido mejor ORDENAR ¿?, ESTRUCTURAR ¿?,

Cita:
Empezado por mcbullrich Ver Mensaje
Y además tenía un problema de servicio técnico:
Tengo una heladera Siam de año 63. Donde puedo conseguir el termostato original? Le puedo adaptar algún otro? Y si la conecto directo? Y si me resigno a tomar la coca caliente?
En fin, se que quizás este no es el foro adecuado...
En éste caso concreto y perfectamente bien explicado seguro que te van a dar la razón

Va
Responder Con Cita
  #11  
Antiguo 26-04-2012
Avatar de JoseAntonio
JoseAntonio JoseAntonio is offline
Miembro
 
Registrado: abr 2006
Ubicación: Lima - Ciudad de los Reyes.
Posts: 87
Poder: 19
JoseAntonio Va por buen camino
Cita:
Empezado por ASAPLTDA Ver Mensaje
Hola Podrias compartir un ejemplo basico para ver como funciona
Si podria, pero no lo hare por ahora, solo te dire que se implemento estas funciones en el modulo de datos:

Código Delphi [-]
function GetDataset(SQL: str): TDataset;
function ExecuteSQL(SQL: string): boolean;
function ExecuteScript(SqL: string): boolean; // ejecuta varias lineas de sql en una sola transacción
lo que se gana con todo esto es que cualquiera puede modificar el codigo de los sistemas puesto que todo esta expuesto y por ende los sistemas son mas robustos y muy depurables, la pega del asunto es que ya no hay enlace entre los componentes y la data directamente porque todo es a mano, pero esto en si también llegaría a ser una ventaja puesto que se gana en versatilidad, a la larga ya no estas apareciendo en tanto foro para preguntar como funciona un dblockupcombobox por dar un ejemplo, puesto que usas un simple combobox o similar y tu mismo lo llenas a mano, cuestion de filosofia.
__________________
nuestro carácter está reflejado en cada línea de código que escribimos.
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
Ayuda para instalar componente svqrbarcode para QReport BlueSteel Varios 4 24-09-2010 23:05:23
Componente para buscar registros, para no repetir codigo. flystar Conexión con bases de datos 9 28-04-2010 23:16:15
como mover todos los componente a un DataModule kurono Varios 8 25-03-2008 02:09:45
Crear un DataModule para Firebird claudiorene Firebird e Interbase 1 13-07-2007 18:01:09
componente para norma19 para delphi7 raulmm26 Varios 3 07-02-2005 12:31:11


La franja horaria es GMT +2. Ahora son las 23:27:18.


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