FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
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 |
#2
|
|||
|
|||
Se me olvido decirlo, estoy usando firebird
Un saludo |
#3
|
||||
|
||||
¿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. |
#4
|
|||
|
|||
Muchas gracias Neftali por contestarme,
Si mira estoy usando los que trae el delphi los IBX.
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 |
#5
|
||||
|
||||
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
|
#6
|
||||
|
||||
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. |
#8
|
|||
|
|||
Si, una cosa, es que quiero que el campo añdido tenga la misma estructura
que un campo de otra tabla |
#9
|
||||
|
||||
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. |
#10
|
||||
|
||||
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
|
#11
|
|||
|
|||
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. |
#12
|
||||
|
||||
Cita:
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. |
#13
|
|||
|
|||
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 |
#14
|
||||
|
||||
Cita:
Cita:
Saludos...
__________________
"Pedid, y se os dará; buscad, y hallaréis; llamad, y se os abrirá." Mt.7:7
|
#15
|
|||
|
|||
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
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 |
#16
|
||||
|
||||
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
|
|
|
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 |
|