Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 11-03-2016
Toni Toni is offline
Miembro
 
Registrado: may 2003
Ubicación: Barcelona - España
Posts: 364
Poder: 22
Toni Va por buen camino
Viendo el ejemplo que puso el compañero Eficsa:

Código Delphi [-]
...
var
  ib: TIBDataSet;
begin
  ib := IBDataSet1;
  ib.Close;
  ib.SelectSQL.Text  := 'SELECT ID, NAME, PASSWORD FROM USUARIO';
  ib.DeleteSQL.Text  := 'DELETE FROM USUARIO WHERE ID = :OLD_ID';
  ib.InsertSQL.Text  := 'INSERT INTO USUARIO (ID, NAME, PASSWORD)VALUES(:ID, :NAME, :PASSWORD)';
  ib.ModifySQL.Text  := 'UPDATE USUARIO SET ID = :ID, NAME = :NAME, PASSWORD = :PASSWORD WHERE ID = :OLD_ID';
  ib.RefreshSQL.Text := 'SELECT ID, NAME, PASSWORD FROM USUARIO WHERE ID = :ID';
  ib.Open;

  ib.Insert;

  ...

  ib.Post;

En este componente hay que generar las siguientes secuencias SQL (select, delete, insert, modify y refresh) y esto se puede hacer manualmente escribiendo el código o con una herramienta que llevan estos controles. Sino me equivoco dicha herramienta tambien es en tiempo de diseño. Ha esto me referia. Espero haberme explicado.
__________________
Saludos,

Bitman
Responder Con Cita
  #2  
Antiguo 11-03-2016
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.044
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Con los componentes IBX solamente necesitas escribir select * from tabla y pulsar el botón "Generar code sql". Se acabó, él genera todas las variantes para insert, delete, update, etc.
Lo explica en los tutoriales que he indicado antes.
Responder Con Cita
  #3  
Antiguo 11-03-2016
Toni Toni is offline
Miembro
 
Registrado: may 2003
Ubicación: Barcelona - España
Posts: 364
Poder: 22
Toni Va por buen camino
Casimiro, esto ya esta claro. Lo que yo decia es que con este sistema si agregas un campo nuevo a la tabla hay que generar de nuevo las sentencias SQL en los componentes que toque.. Y que utilizando la otra combinación de componentes lo hace en tiempo de ejecucion. Por ejemplo en el caso de utilizar una rejilla de datos en una aplicación, con estos componentes tendrias los nuevos campos disponibles y editables sin tener que recompilar la aplicación. Solo estaba aportando otras posibilidades de trabajar con los IBX y las ventajas que le veo.
__________________
Saludos,

Bitman
Responder Con Cita
  #4  
Antiguo 11-03-2016
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.044
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
¿Y cómo detecta que hay un campo nuevo y modifica las sentencias?
Responder Con Cita
  #5  
Antiguo 11-03-2016
Toni Toni is offline
Miembro
 
Registrado: may 2003
Ubicación: Barcelona - España
Posts: 364
Poder: 22
Toni Va por buen camino
Porque como comentaba internamente genera las sentencias SQL cada vez que realizas una operación con el ClientDataSet.

Si tienes un CLIENTDASET + TDATASETPROVIDER +TIBQUERY

Y en el TIBQUERY le ponemos una sentecia SQL tipo: 'select * from Empleados;'

Cada vez que habramos el CDS nos retorna todas las columnas y si modificamos cualquiera de ellas, el DSP genera la SQL con las columnas modificadas/insertadas/borradas. Ha esto me referia con que lo 'genera' en tiempo de ejecucion.

Cuando vas haciendo programas que poco a poco van creciendo te despreocupas un poco de actuailzar todos los IBDataSet. Incluso como decia hay muchos casos que no tienes que recompilar. Rejillas de datos, en listas de campos que se cargan en combobox para realizar una selección, ect.

Pero bueno en definitiva las dos funcionan, aunque a mi personalmente me gusta mas este modo.
__________________
Saludos,

Bitman
Responder Con Cita
  #6  
Antiguo 11-03-2016
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.044
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Pero hay campos que no son necesarios usar/mostrar al usuario, ¿tienes que controlar luego cada campo para decirle que no lo muestre en un dgbrid, por ejemplo?
Responder Con Cita
  #7  
Antiguo 11-03-2016
Toni Toni is offline
Miembro
 
Registrado: may 2003
Ubicación: Barcelona - España
Posts: 364
Poder: 22
Toni Va por buen camino
Lo de la rejilla es solo un ejemplo, para ver como funciona. Pero me resulta bastante comodo no tener que estar siempre modificando y/o actualizando los componentes de datos con las nuevas sentencias sql.
__________________
Saludos,

Bitman
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
Como obtener e instalar algunos componentes para trabajar Bases de Datos JoAnCa Varios 3 12-05-2008 23:57:59
Como trabajar con Kylix oswaldos Lazarus, FreePascal, Kylix, etc. 2 28-01-2006 14:51:11
Como trabajar una DB en red? JuanErasmo Firebird e Interbase 19 27-10-2005 23:44:38
componentes para trabajar sobre Microsoft sql server con Delphi 6 ALMERA Conexión con bases de datos 3 11-05-2005 11:51:52
Trabajar con componentes en excel uper Varios 0 29-07-2004 21:13:58


La franja horaria es GMT +2. Ahora son las 18:48:54.


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