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-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Añadir campo nuevo

Hola a todos

Se puede añadir un campo fisicamente en una tabla?. Con SQL no tengo
ningun problema, usando Alter Table pero con delphi sin usar sql no acierto
a como hacerlo.

Seréis tan amables de decirme si se puede hacer.

Un saludo para todos
Responder Con Cita
  #2  
Antiguo 23-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Se me olvido decirlo, estoy usando firebird

Un saludo
Responder Con Cita
  #3  
Antiguo 23-11-2009
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.293
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
¿Qué componentes de conexión estás utilizando?
¿te da algun error?
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #4  
Antiguo 23-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Muchas gracias Neftali por contestarme,

Si mira estoy usando los que trae el delphi los IBX.

Código Delphi [-]
var
  campo: TField; 
begin
 campo := TField.Create(tblDest);
 campo := tblSource.Fields[3];   //por ejemplo
 tblDest.Fields.Add(campo);
                                           
end;

Entonces me da errores de punteros cuando intento cerrar y abrir las
tablas o no me añade ningún campo, no consigo la persistencia



Muchas gracias a todos
Responder Con Cita
  #5  
Antiguo 23-11-2009
Avatar de rgstuamigo
rgstuamigo rgstuamigo is offline
Miembro
 
Registrado: jul 2008
Ubicación: Santa Cruz de la Sierra-Bolivia
Posts: 1.646
Poder: 17
rgstuamigo Va por buen camino
Arrow

No acabo de entenderte.
Quieres agregar un campo a tu tabla de la base de dato?
ó solo quieres adicionar un campo virtual(calculado,solo para vista)en tu DataSet(Query,Table)?.
Saludos...
__________________
"Pedid, y se os dará; buscad, y hallaréis; llamad, y se os abrirá." Mt.7:7
Responder Con Cita
  #6  
Antiguo 23-11-2009
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.293
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
No he usado mucho las IBX, pero la asignación que estás haciendo no parece muy correcta y puede ser la causante de los errores.
Creas el objeto y luego haces la asignación de un campo ya existente. No se si eso es correcto. De todas formas no te fies 100% porque nunca lo he usado de esta forma.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #7  
Antiguo 23-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Muchas gracias por responderme

Quiero crear un nuevo campo en una tabla física o sea con persistencia
mas o menos lo que se hace con sql así

Código SQL [-]

ALTER TABLE NOMTABLA ADD NuevoCAMPO Integer;

A lo mejor no es posible

Muchas gracias
Responder Con Cita
  #8  
Antiguo 23-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Si, una cosa, es que quiero que el campo añdido tenga la misma estructura
que un campo de otra tabla
Responder Con Cita
  #9  
Antiguo 23-11-2009
Avatar de Axel_Tech
Axel_Tech Axel_Tech is offline
Miembro
 
Registrado: nov 2008
Ubicación: lugar en que está ubicado algo.
Posts: 85
Poder: 16
Axel_Tech Va por buen camino
Y no valdría ejecutar esa misma instrucción SQL con un IBQuery o un IBSQL?
__________________
No hope, no dreams, no love, my only escape is Underground

Última edición por Axel_Tech fecha: 23-11-2009 a las 19:12:42.
Responder Con Cita
  #10  
Antiguo 23-11-2009
Avatar de rgstuamigo
rgstuamigo rgstuamigo is offline
Miembro
 
Registrado: jul 2008
Ubicación: Santa Cruz de la Sierra-Bolivia
Posts: 1.646
Poder: 17
rgstuamigo Va por buen camino
Arrow

Pues eso...mismo...
Tranquilamente puedes ejecutar una sentencia SQL en un IBQuery(Tal como te indica Axel_Tech) y adicionar la columna que quieras en tu tabla de tu base de datos..
Saludos...
__________________
"Pedid, y se os dará; buscad, y hallaréis; llamad, y se os abrirá." Mt.7:7
Responder Con Cita
  #11  
Antiguo 23-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Ya si eso ya lo hice y funciona, pero quería hacerlo sin utilizar SQL como ya puse al principio del post. Porque se complica cuando extraemos el DataType en delphi de la estructura delcampo que quiero copiar y ponerlo en el sql. Un ejemplo seríapara un DataType ftInteger en el sql habria que poner Integer y de estaforma me tengo que mirar todos los tipos y hacer una sentencia sql paracada tipo. Por eso quería hacerlo sin utilizar sql por si habria alguna
forma de crear un campo que la estructura fuera la copia de otro y añadirlo a una tabla existente.

He estado buscando y no veo que se pueda hacer.

De todas formas muchas gracias a todos.
Responder Con Cita
  #12  
Antiguo 23-11-2009
Avatar de rgstuamigo
rgstuamigo rgstuamigo is offline
Miembro
 
Registrado: jul 2008
Ubicación: Santa Cruz de la Sierra-Bolivia
Posts: 1.646
Poder: 17
rgstuamigo Va por buen camino
Arrow

Cita:
Empezado por jaimeh Ver Mensaje
Ya si eso ya lo hice y funciona, pero quería hacerlo sin utilizar SQL como ya puse al principio del post. Porque se complica cuando extraemos el DataType en delphi de la estructura delcampo que quiero copiar y ponerlo en el sql. Un ejemplo seríapara un DataType ftInteger en el sql habria que poner Integer y de estaforma me tengo que mirar todos los tipos y hacer una sentencia sql paracada tipo. Por eso quería hacerlo sin utilizar sql por si habria alguna
forma de crear un campo que la estructura fuera la copia de otro y añadirlo a una tabla existente.

He estado buscando y no veo que se pueda hacer.

De todas formas muchas gracias a todos.
Amigo jaimeh, creo que estas confundiendo algunas cosas. me explico.
Un componente DataSet que puede un TQuery,TTable,TIBQuery,TIBTable,TZQuery,etc,etc,etc, no significa que es tu Tabla de tu base de Datos. Es decir el hecho de que se adicione un Field(campo) a mi DataSet en mi aplicacion, no significa que se este adicionando un Campo en mi tabla en la Base de Datos.(Pareciera que tu lo estas tomando asi).
Estos Dataset son solo componentes que Delphi te provee para la gestion de datos hacia o desde tu Servidor de Base de Datos.Una cosa son tus tablas en tu Base de dato y otra cosa son tus Query,Tables en tu aplicacion.
Entonces debes entender la forma de trabajo de estos DataSet.
Eso significa que la unica forma de Cambiar la estructura de una tabla en tu Base de datos(Modificar columnas,crear tablas,crear base de datos,etc), pues es atraves de sentencias SQL; a menos que tu te crees componentes que te hagan eso, es mas, internamente los Dataset utilizan SQL, y si tu te creas un componente,logicamente tienes que usar sentencias SQL para poder comunicarte con el servidor de Base de datos; aunque quisas el usuario de tu componente no sabe que es asi.
Los DataSet solo reflejan lo que esta en tus tablas de base de datos.
Asi fue como Borland diseño tales componentes y esa es la lógica.
Saludos...
__________________
"Pedid, y se os dará; buscad, y hallaréis; llamad, y se os abrirá." Mt.7:7

Última edición por rgstuamigo fecha: 23-11-2009 a las 20:35:43.
Responder Con Cita
  #13  
Antiguo 23-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
amigo rgstuamigo

Se que los dataset no son las tablas. Pero como hay sentancias Fields.add y
fieldefs.add pensaba si se podía conseguir algo. De hecho con fielddefs.add
y createtable se puede crear una tabla sin utilizar el sql aunque el componente lo utilice internamente.

saludos
Responder Con Cita
  #14  
Antiguo 23-11-2009
Avatar de rgstuamigo
rgstuamigo rgstuamigo is offline
Miembro
 
Registrado: jul 2008
Ubicación: Santa Cruz de la Sierra-Bolivia
Posts: 1.646
Poder: 17
rgstuamigo Va por buen camino
Arrow

Cita:
Empezado por jaimeh Ver Mensaje
amigo rgstuamigo

Se que los dataset no son las tablas. Pero como hay sentancias Fields.add y
fieldefs.add pensaba si se podía conseguir algo. De hecho con fielddefs.add
y createtable se puede crear una tabla sin utilizar el sql aunque el componente lo utilice internamente.

saludos
Sacado de la ayuda de Delphi 7 >
Cita:
Inserts a new field to the end of the Fields array.

Delphi syntax:

procedure Add(Field: TField);

C++ syntax:

void __fastcall Add(TField* Field);

Description

Applications do not normally call the Add method directly. When field objects are created, Add is called automatically by the dataset.
Por otra parte seria interesante que pusieras el codigo de como has logrado crear tablas usando fielddefs.add,talves es algo nuevo para mi.
Saludos...
__________________
"Pedid, y se os dará; buscad, y hallaréis; llamad, y se os abrirá." Mt.7:7
Responder Con Cita
  #15  
Antiguo 23-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Hola de nuevo

Lo de la ayuda de delphi 7 entiendo que no se puede llamar directamente a add. No se hasta que punto lo llamaba directamente.

Aqui os pongo el código que me habéis pedido
Código Delphi [-]

procedure CrearTabla(NomTabla: String);

begin



   if NOT FTablas2.IBTable1.Transaction.Active then
      FTablas2.IBTable1.Transaction.StartTransaction;

//   if FTablas2.IBTable1.Active then
//     FTablas2.IBTable1.Close;


    FTablas2.IBTable1.TableName := NomTabla;  // nomTabla;

   try
     if FTablas2.IBTable1.Exists then
     begin

      FTablas2.IBTable1.DeleteTable;
      FTablas2.IBTable1.Transaction.Commit;
     end;
   Except
     on E: Exception  do
      Application.MessageBox( PChar( E.ClassName + ': ' + E.Message ),
                             'Error', MB_ICONSTOP );
   end;

   FTablas2.IBTable1.FieldDefs.Clear;

   FTablas2.IBTable1.FieldDefs.Add('Numero', ftInteger);
   FTablas2.IBTable1.FieldDefs.Add('Nombre', ftString, 32);
   FTablas2.IBTable1.FieldDefs.Add('Codigo', ftInteger);
   FTablas2.IBTable1.FieldDefs.Add('Cantidad', ftInteger);
   FTablas2.IBTable1.FieldDefs.Add('Cantidadx100', ftString, 5);





   if NOT FTablas2.IBTable1.Transaction.Active then
      FTablas2.IBTable1.Transaction.StartTransaction;

   try
     FTablas2.IBTable1.CreateTable;
     FTablas2.IBTable1.Transaction.Commit;
   Except
     on E: Exception  do
      Application.MessageBox( PChar( E.ClassName + ': ' + E.Message ),
                             'Error', MB_ICONSTOP );
   end;



end;


Esto me crea una tabla física persistente, con 5 campos, en una base de datos firebird.

Espero que haya servido para algo.



Saludos a todos
Responder Con Cita
  #16  
Antiguo 24-11-2009
Avatar de rgstuamigo
rgstuamigo rgstuamigo is offline
Miembro
 
Registrado: jul 2008
Ubicación: Santa Cruz de la Sierra-Bolivia
Posts: 1.646
Poder: 17
rgstuamigo Va por buen camino
Arrow

Tal parece que si se puede amigo jaimeh..., aunque no he trabajado con Interbase o Firebird ,creo que los componentes de la paleta Interbase tienes muchas cosas interesante,...vaya desconocia que tuvieran esas caracteristicas,y tambien se puede crear tablas con el TTable de la paleta BDE Aunque como hemos dicho internamente usan SQL...Vaya...Buen aporte jaimeh.
Saludos...
__________________
"Pedid, y se os dará; buscad, y hallaréis; llamad, y se os abrirá." Mt.7:7
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
Añadir campo por codigo kalimero Impresión 1 16-02-2009 18:23:46
Añadir un campo a una tabla franfl Firebird e Interbase 6 03-03-2008 22:21:51
¿Cuál es el tipo compatible con Number para añadir un nuevo campo calculado de ese t? nuri SQL 2 26-07-2005 11:24:34
Como añadir un nuevo evento a un componente Javi2 Varios 6 20-12-2004 13:25:12
Añadir Campo a TSQLQuery asirvent Conexión con bases de datos 2 20-06-2003 16:30:17


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


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