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 Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 24-11-2015
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
Como trabajar con los componentes ibx

Hola amigos,
Aquí sigo dando la lata con nuevas cosas. .
Resulta q, he usado y uso los componentes zeos para firebird, sin problema, quizá no al, 100%, pero me sirven.
Leyendo post sobre otros componentes para, lazarus y firebird, quise probar ibx, pero me están dando bastantes quebraderos de cabeza porque no funcionan igual que los zeos.
Si he conseguido conectarme y ver la base de datos, pero otras odas como editar o insertar no he podido.
Alguno sabe, además de los ejemplos, de como se usan?
Gracias
Responder Con Cita
  #2  
Antiguo 24-11-2015
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.021
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
http://www.intitec.com/varios/Delphi...rd_con_ibx.pdf
http://www.clubdelphi.com/foros/showthread.php?t=68708

Última edición por Casimiro Notevi fecha: 24-11-2015 a las 10:39:57.
Responder Con Cita
  #3  
Antiguo 30-11-2015
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
Gracias por los, aportes, si me sirven y mucho
Responder Con Cita
  #4  
Antiguo 20-02-2016
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
Hola amigos, aqui dando lata,
las cosas no van muy bien que digamos pero bueno, en el poco tiempo que tengo para hacer cosas, al menos lo intento.

Instale los componentes ibx de nuevo despues de arreglar las computadoras,

Consultas con los ibx no tengo, aparentemente problemas, pero a la hora de insertar registros si los tengo.
Estuve dandole vueltas al tutorial que me puso Casimiro Notevi, y de esa forma si,trabajan, pero si lo quiero hacer a mano ya no lo hace.
Me explico,
A la hora de usar el editor de ibxdataset1, genero las consultas, inserciones, etc, y quedan almacenadas en selectSQL y etc,
si yo pongo

Código Delphi [-]
  ibdataset1.SelectSQL.Clear;
  ibdataset1.SelectSQL.Text:='select * from usuarios';
  ibdataset1.Open;
  ibdataset1.Insert;
  ibdataset1.fieldbyname('nick').asstring:=enick.text;
  ibdataset1.Post;
  IBTransaction1.CommitRetaining;
ya nose, la verdad que estoy haciendo mal ahi, porque tenia en

Esa estructura esta bien?. o asi no se debe.
No entiendo muy bien para que me sirve el insertsql que viene integrado en el ibxdataset1 si lo tengo que ir poniendo yo las cosas como cuando trabajaba con zeos.

perdon por ser repetitivo.
gracias

Última edición por ecfisa fecha: 20-02-2016 a las 05:42:15. Razón: corregir wyiswyg
Responder Con Cita
  #5  
Antiguo 20-02-2016
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 anubis.
Cita:
Empezado por anubis Ver Mensaje
...
Estuve dandole vueltas al tutorial que me puso Casimiro Notevi, y de esa forma si,trabajan, pero si lo quiero hacer a mano ya no lo hace.
Me explico,
A la hora de usar el editor de ibxdataset1, genero las consultas, inserciones, etc, y quedan almacenadas en selectSQL y etc,
si yo pongo

Código Delphi [-]
  ibdataset1.SelectSQL.Clear;
  ibdataset1.SelectSQL.Text:='select * from usuarios';
  ibdataset1.Open;
  ibdataset1.Insert;
  ibdataset1.fieldbyname('nick').asstring:=enick.text;
  ibdataset1.Post;
  IBTransaction1.CommitRetaining;
ya nose, la verdad que estoy haciendo mal ahi, porque tenia en

Esa estructura esta bien?. o asi no se debe.
...
Trabajando con el TIBDataSet de forma manual, si solo asignas la propiedad SelectSQL como en el código que mostras, el componente se comportará de modo similar que si hubieses lanzado una consulta mediante un TIBQuery.

Para poder aprovechar las facilidades que ofrece el componente TIBDataSet (como los métodos: Delete, Insert, Append, Post) también tenes que configurar de forma manual sus propiedades DeleteSQL, InsertSQL, ModifySQL y RefreshSQL. Ejemplo:
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;
Pero generalmente es mucho mas simple y rápido usar la herramienta SQL Generation que trae el componente.

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #6  
Antiguo 20-02-2016
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
Gracias por contestar amigo, .

La herramienta de generacion si la he visto, lo que no entiendo muy bien es como, una vez generado, puedo usarla para seleccionar o insertar, como le puedo pasar despues los parametros, porque no lo veo muy claro.
Perdon por no entender.

edito: en la generacion por ejemplo de
selectsql, intento usarla
Código Delphi [-]
ibdataset1.selectsql;

pero me dice que esta vacia.
entonces uso lo mismo que esta en el selectsql generado

Código Delphi [-]
ibdataset1.selectsql.text:='select * from usuarios';
asi si funciona, por eso digo que no entiendo entonces o de que forma se usaria el select, o los otros inclusive pasando parametros de forma manual como por ejemplo, para hacer filtros o consultas.

Última edición por anubis fecha: 20-02-2016 a las 06:34:20.
Responder Con Cita
  #7  
Antiguo 20-02-2016
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
Cita:
Empezado por anubis Ver Mensaje
Gracias por contestar amigo, .

La herramienta de generacion si la he visto, lo que no entiendo muy bien es como, una vez generado, puedo usarla para seleccionar o insertar, como le puedo pasar despues los parametros, porque no lo veo muy claro.
...
Una vez generadas las sentencias SQL, por ejemplo para insertar un registro:
Código Delphi [-]
...
var
  ib: TIBDataSet;
begin
  ib := IBDataSet1; 
  ib.Open;
  ib.Insert;
  ib.FieldByName('NAME').AsString := 'pepe';
  ib.FieldByName('PASSWORD').AsString := '1234';
  ib.Post;
...
Para hacer consultas, usándolo al modo de un TIBQuery, solo configura la propiedad SelectSQL como si fuese cualquier query.
Para filtrar usa la propiedad Filter como con cualquier dataset.

Saludos
__________________
Daniel Didriksen

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

Última edición por ecfisa fecha: 20-02-2016 a las 07:07:12.
Responder Con Cita
  #8  
Antiguo 20-02-2016
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
gracias otra vez.

Asi si me consta de usar el insert, pero el insertsql que ya trae todo, no hace falta entonces?
Responder Con Cita
  #9  
Antiguo 20-02-2016
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 anubis
Cita:
Empezado por anubis Ver Mensaje
gracias otra vez.

Asi si me consta de usar el insert, pero el insertsql que ya trae todo, no hace falta entonces?
Habiendo configurado en tiempo de diseño las sentencias SQL con el SQL Generation no es necesario.

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #10  
Antiguo 20-02-2016
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.021
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por anubis Ver Mensaje
Estuve dandole vueltas al tutorial que me puso Casimiro Notevi, y de esa forma si,trabajan, pero si lo quiero hacer a mano ya no lo hace.
Me parece que no has seguido bien el tutorial
Responder Con Cita
  #11  
Antiguo 21-02-2016
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
Hola Casimiro Notevi, puede que tengas razón y no lo vi bien , solo estuve intentando alternativas puesto que en el tutorial usa un navigator y yo no queria usar un control navigator y hacerlo con codigo.
Mis disculpas
Responder Con Cita
  #12  
Antiguo 21-02-2016
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.021
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por anubis Ver Mensaje
Hola Casimiro Notevi, puede que tengas razón y no lo vi bien , solo estuve intentando alternativas puesto que en el tutorial usa un navigator y yo no queria usar un control navigator y hacerlo con codigo.
Lo del "navigator" es solamente para no complicar el ejemplo del tutorial, pero si sigues leyéndolo llegarás al momento en que se crean todas las sentencias sql (select, update, delete...) sin que tengas que escribirlas tú, lo hace el componente.
Responder Con Cita
  #13  
Antiguo 22-02-2016
Toni Toni is offline
Miembro
 
Registrado: may 2003
Ubicación: Barcelona - España
Posts: 364
Poder: 21
Toni Va por buen camino
Hola,

Quizas una forma mas comoda de trabajar con los IBX es hacerlo conjuntamente con los ClientDataSet y los DataSetProvider. El modelo de trabajo seria asociando uno a otro de la siguiente forma:

TClientDataSet -> TDataSetProvider -> TIBQuery

la ventaja de utilizar de esta forma es que no tienes que no tienes que construir todas las sql (select, update, insert) lo hace por ti el TDataSetProvider, lo que lo hace bastante comodo. Por otro lado tambien te maneja las transacciones ya que cuando haces una consulta descarga toda la información sobre el TClientDataSet en memoria y no tienes la transaccion abierta.

Con este modelo pudes hacer tanto consultas como modificaciones e inserciones.
__________________
Saludos,

Bitman
Responder Con Cita
  #14  
Antiguo 22-02-2016
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.021
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por Toni Ver Mensaje
la ventaja de utilizar de esta forma es que no tienes que no tienes que construir todas las sql (select, update, insert) lo hace por ti el TDataSetProvider, lo que lo hace bastante comodo.
Eso también lo hace los IBX.
Responder Con Cita
  #15  
Antiguo 11-03-2016
Toni Toni is offline
Miembro
 
Registrado: may 2003
Ubicación: Barcelona - España
Posts: 364
Poder: 21
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
  #16  
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.021
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
  #17  
Antiguo 11-03-2016
Toni Toni is offline
Miembro
 
Registrado: may 2003
Ubicación: Barcelona - España
Posts: 364
Poder: 21
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
  #18  
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.021
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
  #19  
Antiguo 11-03-2016
Toni Toni is offline
Miembro
 
Registrado: may 2003
Ubicación: Barcelona - España
Posts: 364
Poder: 21
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
  #20  
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.021
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
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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


La franja horaria es GMT +2. Ahora son las 00:40:58.


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