Migrar estructura de tablas paradox a Firebird
Hola todos
Quiero ejecutar un script para crear tablas de firebird pero desde Delphi. Ya he conseguido crear la tabla desde Delphi pero ahora no encuentro como crear las tablas. ¿alguno de ustedes me puede decir como hacer esto? Salud OS y gracias. |
Puedes usar el componente TIBScript para ejecutar scripts DDL...
Saludos... |
Muchas gracias maeyanes, lo voy a probar y comento los resultados.
Salud OS. |
Bueno pues muchas gracias maeyanes, las tablas fueron creadas perfectamente.
Ahora les voy a comentar el porque de esto, resulta que como soy muy flojo, como dirian por aqui algunos "soy un vago", estoy migrando los sistemas que tengo de Paradox a Firebird, pero (como siempre hay un pero), me da flojera estar creando las tablas desde el IBExpert. Por tal razón me puse a la tarea de crear un programita para migrar las definiciones de las tablas sin tener que escribir nada, es decir, solo selecciono el Alias que quiero migrar y el sistema me genera el script de la base. Una vez que el script está generado, con un simple click creo la base de datos en Firebird y las tablas. Aquí les pego el código fuente para quien le interese y también al igual que yo le de flojera esta migración. Hay algunos detalles que no se como atacarlos, por ejemplo, los campos Blob o Memo de paradox, no se su correspondencia en Firebird, de igual forma no he puesto todos los tipos de datos, solo incluí los digamos tipos estandard. Se que por aqui habrá quien le de su toque maestro y espero que éste se vea favorecido por sus aportaciones. Edito: Hay un bug, pero es por la razón que les comenté, no he incluido todos los tipos de datos, por lo tanto, les puede enviar un error cuando el último campo de la tabla es de un tipo NO incluido. Otra cosa, aun me falta asignar las llaves, los campos NOT NULL, pero estoy trabajando en eso. Salud OS. |
Esto te puede servir
lo puedes hacer para los para las llaves, etc. |
Gracias por tu comentario Manuel.
Pues yo sigo con el tema, hubo unos cambios en el programita, cambie el TQuery por un TTable para poder encontrar los índices, en este primer cambio ya logre ingresar el primer índice y funciona bien, sigo aún con el bug de los campos NO incluidos, pero quise primero ver lo de los índices. En esta parte solo se crea el índice pero no la llave primaria, sigo buscando información para poder lograrlo. Aquí pueden bajar el código fuente. Salud OS. |
Sigo tratando de mejorar el programa y debo pedirles una disculpa a los que ya hayan bajado el mismo porque no lo habia subido completo.
Aqui la última versión la cual ya genera las llaves primarias. Espero les guste y sobre todo que les sea de utilidad. Salud OS. |
Hola egostar.
Si queres puedes subir el código fuente al FTP público; No he querido hacerlo yo, por si tienes algun inconveniente. Lo digo porque así seguro que "perdura" más tiempo y lo tenemos más accesible si más adelante queremos buscarlo. Gracias por el código. |
Un detalle, no uses double precision, usa NUMERIC(10,2) para campos monetarios en Dialecto 3, o tendrás problemas de redondeos y verás que guarda valores que no se corresponden con los introducidos.
Me ha extrañado que al ser un campo indexado, añadas la restricción NOT NULL, eso más bien sería si el campo es obligatorio (Required) ¿no?. Bueno, quizás tú lo necesites así. Por lo demás me parece fantastico el código. Si se puede aportar algo... así puedes saber cual es la clave primaria y crear los índices.
Saludos |
Otro pequeño aporte:
|
Cita:
Cita:
Cita:
Cita:
Cita:
Salud OS. |
Cita:
|
Cita:
Salud OS. |
Ya he conseguido incluir las mejoras que amablemente me han dejado saber.
Ahora y tomandole la palabra a Neftali, quiero subir el programa al FTP de Club Delphi, pero tengo una pregunta, como es un programa que aún creo le faltan muchas mejoras, al subirlo al FTP, ¿puedo sobreescribirlo con las últimos cambios posteriormente? o se agrega uno cada vez que lo subo (por supuesto que lo haría con el mismo nombre). Salud OS y gracias. |
Bueno, pues he alojado el programa en el FTP de Club Delphi.
[Herramienta] Migrar estructura de bases Paradox a Firebird Pdox2FB.zip
Salud OS. |
Hola amigos
Antes que nada, agradezco a todos los que han leido este hilo. Y pues yo sigo con mi "juguete" de migrar tablas Paradox a Firebird y la intención de este nuevo mensaje es la de dejarles saber que además de la estructura de la base de datos ya he podido migrar los datos de las tablas Paradox a Firebird. Se que aún quedan muchas cosas por hacer y algunos problemas de casting pero mi pobre conocimiento me limita a hacerlo muy lentamente. Se que hay herramientas poderosas que hacen esto mismo, pero como les digo, es un juguete que se me ocurrio desarrollar y que me ha evitado algunos minutos de trabajo extra al estar migrando mis sistemas a Firebird. Ya he subido al FTP del Club la nueva versión y espero que les agrade, si fuera posible me gustaría que me retroalimentaran con sus comentarios, criticas y sugerencias. Aqui pueden bajar este pequeño aporte de mi parte, no tiene restricción alguna, asi que no le he puesto licencia de ningún tipo. [Herramienta] Migrar Tablas Paradox a Firebird Pdox2FB.zip Saludos y gracias por leerme. Sinceramente Eliseo. |
Hola Eliseo!
Antes que nada quisiera felicitarte por tu trabajo, me parece una genial idea esta herramienta para automatizar la conversión entre bases de datos. Esperé hasta llegar a mi casa para poder descargarlo y probarlo con calma, me gustaría hacerte algunas observaciones de lo que me he encontrado hasta ahora. En primer lugar yo tengo Delphi 7 y veo que tu usas una versión más reciente, mi pregunta es ¿puedo utilizar Turbo Delphi Explorer para compilarlo?. Con respecto a la aplicación, mi primera prueba fue la siguiente: Tomé el Alias que viene incluido al instalar las bases de datos Demo de Delphi 7, es decir DBDEMOS, la aplicación llena la lista con todas las tablas que encuentra la ruta, sin embargo no todas las tablas tienen la extensión *.db algunas son *.dbf. Como consecuencia al intentar crear el script para la primera tabla que es Animals.DBF me genera el siguiente error: Mi segunda prueba fue abrir un Alias con unas tablas de paradox que tenía guardadas, el problema según veo es que coloqué acentos en los nombres de las tablas. Me genera el script para crear las tablas, pero los acentos son permitidos en Paradox y no en Firebird, por lo tanto me envía un error al crear la base de datos. Por último me gustaría hacer una sugerencia, sería excelente poder guardar una copia de los scripts que se hayan creado con tu aplicación, incluyendo la sentencias que crean la base de datos y los INSERT para la migración de datos. Esto en ocasiones es útil ya que me puedo llevar estos archivos para ejecutarlos desde la consola o en IBExpert y así me das la oportunidad de agregarle o quitarle líneas para afinar detalles antes de crear la base de datos. Algo así como esto:
Bueno, por el momento es todo y quedo en espera de que me indiques como lo puedo compilar para colaborar en algo. Saludos |
Muchas gracias por tu interes Hector.
Si efectivamente no me ha funcionado mas que para base de datos del tipo Paradox (db), seguiré investigando para que lo haga con las DBF. También agregaré la parte de quitar acentos, muchas gracias por la nota, yo nunca he utilizado acentos por lo que no visualice esté punto. Por la parte de crear el archivo, agregaré esa opción muchas gracias por el apunte también. Te agradezco mucho tus comentarios. Salud OS. |
Cita:
Muchas gracias. |
Hola amigos,
Pues nada, he realizado algunos cambios al codigo de mi "juguetito" en base a los comentarios de Héctor Randolph (muchas gracias) y bueno ya he subido la nueva versión al FTP del Club. [Herramienta] Migrar Tablas Paradox a Firebird v1.zip Salud OS. |
Hola de nuevo,
Pues nada, sigo aqui de enfadoso:o modificando mi juguetito. En esta versión ya pude obtener la estructura de tablas DBF, resulta que la propiedad TableName por default asigna la extensión DB, por lo tanto, asigné directamente la extensión DBF en caso de que la tabla no sea DB. Esto lo realice con un TRY....EXCEPT y ya funcionó. También logré importar la estructura de una base SQL Server, pero hay tipos de datos que aún desconozco su igualdad en Firebird, pero estoy trabajando para obtener todos los tipos de datos. Encontré un error de tipo en el DATETIME, lo estaba pasando así a Firebird y no, el tipo es TIMESTAMP. Esta versión la podrán bajar en [Herramienta] Migrar Tablas Paradox a Firebird Pdox2FB v3.zip Nuevamente agradezco su interes en leer este hilo. Salud OS. |
Saludos
Cita:
Solo que tengo un problema no lo he podido descargar para hacer una mejor evaluacion. Hasta ahorita solo he leido todas las aportaciones que te han hecho y los avances que has estado agregando. De ante mano gracias |
Hola vlanka24, muchas gracias por leerme.
Lo que pasa es que he estado modificando el programa y he subido varias versiones en el FTP, sin embargo, como es lógico, se borran las anteriores y solo queda la última versión. Puedes bajar la última version de aquí [Herramienta] Migrar Tablas Paradox a Firebird Pdox2FB v3.zip Estoy por subir una nueva versión con modificaciones y correcciones y se los dejare saber en cuanto lo haga. Salud OS y muchas gracias por tu interes, espero te sea útil. |
Cita:
Antes que nada quisiera agraceder que hayas tomado en cuenta mis comentarios y también quiero aprovechar para reportarte lo siguiente antes de que subas una nueva versión: Los cambios anteriores con respecto a los acentos en los nombres de tablas y campos funcionan de maravila, excepto cuando se trata de las llaves primarias, es decir, cuando creas el PRIMARY KEY sigue enviando los campos con acentos. Por lo pronto nu hubo tanto problema porque gracias a que puedo guardar el script generado, lo pude corregir manualmente y lo ejecuté en la consola sin problemas. Bueno, por el momento es todo y en los próximos días estoy planeando instalar Turbo Delphi para poder compilar el programa. En realidad el componente que no me permite compilar es IBScript, porque la versión de IBX que yo tengo no tiene dicho componente. Saludos |
Hola Hector,
Al contrario, el agradecido soy yo que he contado con tus acertados comentarios, creo recordar que una de las modificaciones que tengo en la última versión es precisamente esa de la PRIMARY KEY, además de otra cuantas con respecto a la migración de datos, sobre todo en el tipo de dato que se desea exportar. Bueno, pues nada, se que hay herramientas profesionales que hacen esto mismo, pero, además de que me está sirviendo para aprender (que mucha falta me hace) quiero de alguna forma corresponder a todo lo que he recibido en el club y que agradezco sobremanera. Nos leemos en la próxima. Salud OS. |
Hola,
Nuevamente por aquí, les comento que he subido la última versión de mi juguetito, Pdox2FB v1.0.0.4. He estado buscando pero aún no encuentro la forma de migrar los datos del tipo BLOB, MEMO a Firebird, esto lo debo hacer con SQL, si alguno de ustedes sabe como hacerlo, le agradecería me lo dejara saber. Agradezco mucho a todos los que han tenido el interés de leerme y espero que esto les sirva de algo. Aqui podrán bajar la nueva versión. [Herramienta] Migrar Tablas Paradox a Firebird Pdox2FB v4.zip Salud OS. PD: Un favor a los moderadores podrían borrar la versión anterior, muchas gracias. |
Creo que tendrás que usar parámetros. Yo lo haría así
|
Hola basti,
Muchas gracias, me parece una idea excelente, asi que voy a implementarla y te dejaré saber los resultados. Salud OS. |
Hola egostar!
Ante todo gracias por tu aportacion con la aplicación para pasar de paradox a firebird. Es justo lo que necesito , ¿la v.4 es la ultima versión que has hecho?. Si tienes algunas mas actual agreceria muchisimo que la subieras en el ftp. Graciasssssssssss |
Cita:
Al contrario gracias a ti por dejarme saber que fué útil mi "juguetito". Si, la versión 4 es la última, desgraciadamente (o mas bien afortunadamente) he tenido mucho trabajo y no lo he podido actualizar, si tienes algún comentario que sirva para agregar funcionalidades al programa será bienvenido y te lo agradeceré mucho. Salud OS. |
La franja horaria es GMT +2. Ahora son las 09:49:24. |
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