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
Cita:
Empezado por Casimiro Notevi Ver Mensaje
Eso también lo hace los IBX.
Pero sino me equivoco lo hace en tiempo de diseño, y con los DataSetProvider lo hace automaticamente en tiempo de ejecución y de forma transparente. Ademas de mejorar el uso de las transacciones porque carga los datos en memoria en el ClientDataSet y cierra la transacción.
__________________
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.054
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por Toni Ver Mensaje
.con los DataSetProvider lo hace automaticamente en tiempo de ejecución..
La verdad es que no entiendo bien lo que comentas sobre eso.
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
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
  #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.054
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
  #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
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
  #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.054
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
  #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
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
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 05:21:49.


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