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 23-08-2004
RobertoAmores RobertoAmores is offline
Miembro
 
Registrado: jul 2004
Posts: 10
Poder: 0
RobertoAmores Va por buen camino
Como coger datos de un DBGrid

Soy nuevo en el mundo de Delphi, y estoy haciendo una pequeña aplicación que pulsado un boton recoge resgistros de un archivo XML y los presenta en un DBGrid. Uso para esto un ClientDataSet, un DataSource y un XMl TransfromProvider. Hasta ahi todo perfecto, pero luego quiero que esos registros se guarden al pulsar otro boton en la tabla correspondiente en una BD de InterBase. No se como hacerlo, no se si debo recoger los datos del DBGrid o del mismo DataSource que provee al DBGrid. Alguien tiene alguna idea?
Responder Con Cita
  #2  
Antiguo 23-08-2004
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 RobertoAmores
No se como hacerlo, no se si debo recoger los datos del DBGrid o del mismo DataSource que provee al DBGrid.
Del datasource (o mejor dicho del dataset) asociado al dbgrid.

// Saludos
Responder Con Cita
  #3  
Antiguo 24-08-2004
Avatar de Cabanyaler
Cabanyaler Cabanyaler is offline
Miembro
 
Registrado: jun 2003
Ubicación: País Valencià
Posts: 339
Poder: 21
Cabanyaler Va por buen camino
Hola, evidentemente si el DBGrid está en ese caso asociado a un Datasource asociado a su vez con el DataSet, te debe dar lo mismo lo escojas del DataSet tanto como del DBGrid, pero como te dice el compañero es mejor sacar los datos del mismo DataSet, siempre que no hubiese movido el puntero de la tupla que deseas obtener los datos.

No obstante también podrías sacar la información del DBGrid del siguiente modo;

TablaInterbase.edit; // o .insert, append

TablaInterbaseNomCampo1.value := NombreDBGrid.Fields[0].Value;
.
.
.
TablaInterbaseNomCampoN.value := NombreDBGrid.Fields[N-1].Value;
TablaInterbase.Post; // o UpdateBatch()


Siempre teniendo en cuenta los tipos asignados a los campos de acuerdo con las columnas que representa el DBGrid, teniendo en cuenta que el índice de campos del DBGrid comienza con el 0.

Suerte.
__________________
El meu país és tan petit, que des de dalt d'un campanar es pot veure el campanar veí.
Responder Con Cita
  #4  
Antiguo 25-08-2004
RobertoAmores RobertoAmores is offline
Miembro
 
Registrado: jul 2004
Posts: 10
Poder: 0
RobertoAmores Va por buen camino
Gracias por tu ayuda, con ese código casi lo he conseguido, lo que pasa es que solo lee la primera fila del DBGrid, sabrias como adelantar el puntero?
Responder Con Cita
  #5  
Antiguo 25-08-2004
RobertoAmores RobertoAmores is offline
Miembro
 
Registrado: jul 2004
Posts: 10
Poder: 0
RobertoAmores Va por buen camino
Gracias por tu ayuda, casi me funciona ya la aplicacion, lo q pasa es que me saltan diferences excepciones, y algunas veces carga el primer dato y otras veces ninguno, este es el código del click boton:

procedure TForm1.Button1Click(Sender: TObject);
begin
IBTable1.Active:=True;
While not ClientDataSet1.Eof do
begin
IBTable1.Insert;
IBTable1.FieldByName('C_MENS_COD').Value := ClientDataSet1.Fields[0].Value;
IBTable1.FieldByName('N_IND').Value := ClientDataSet1.Fields[1].Value;
IBTable1.FieldByName('C_COD_INT').Value := ClientDataSet1.Fields[2].Value;
IBTable1.FieldByName('C_MENS').Value := ClientDataSet1.Fields[3].Value;
IBTable1.FieldByName('C_TIPO').Value := ClientDataSet1.Fields[4].Value;
IBTable1.FieldByName('C_ORIG').Value := ClientDataSet1.Fields[5].Value;
IBTable1.FieldByName('C_MENS_INT').Value := ClientDataSet1.Fields[6].Value;
IBTable1.FieldByName('C_MOD').Value := ClientDataSet1.Fields[7].Value;
IBTable1.FieldByName('L_PAR').Value := ClientDataSet1.Fields[8].Value;
ClientDataSet1.Next;
end;
IBTable1.Post;
IBTable1.Active:=False;
end;


Una de las excepciones que me salta es esta:

Project Proyecto.exe raised exception class EDatabaseError with message "IBTable1: DataSet not in edit or insert mode"...

El IBTable1 no tiene DataSet, a cual se refiere? Puede ser esta la causa de mi problema?
Responder Con Cita
  #6  
Antiguo 25-08-2004
Avatar de Cabanyaler
Cabanyaler Cabanyaler is offline
Miembro
 
Registrado: jun 2003
Ubicación: País Valencià
Posts: 339
Poder: 21
Cabanyaler Va por buen camino
Bueno, eso haciendo una traza del flujo del programa enseguida se descubre. Suerte.
__________________
El meu país és tan petit, que des de dalt d'un campanar es pot veure el campanar veí.
Responder Con Cita
  #7  
Antiguo 25-08-2004
RobertoAmores RobertoAmores is offline
Miembro
 
Registrado: jul 2004
Posts: 10
Poder: 0
RobertoAmores Va por buen camino
y como se hace una traza desde Delphi?
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


La franja horaria es GMT +2. Ahora son las 11:22:11.


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