He encontrado esta interesante orden dentro de la linea de comando de sqlite3:
.schema
Sirve para listar las tablas y vistas que tengamos definida en la base de datos.
Pregunta ¿hay una forma de hacer un script en bash para que esa información la pase a un archivo de texto plano?
Nota:
He visto en sqlite manager (complemento de firefox), que también tiene esa opción en el menú:
Pero mi idea es crear un pequeño programa al que solo se le pase el nombre de la base de datos, y el esquema lo obtenga el programa automáticamente.
SQLITE3 .schema: Obtener El Esquema De La Base De Datos
Objetivo: Re: SQLITE3 .schema: Obtener El Esquema De La Base De Datos
Todas las bases de datos sqlite tienen una tabla llamada sqlite_master que contiene la definición de todas las tablas.
Supongo que el .schema lo que te da lo saca de esa tabla.
Pero con un
es suficiente.
Saludos.
Supongo que el .schema lo que te da lo saca de esa tabla.
Pero con un
es suficiente.
Saludos.
Objetivo: Re: SQLITE3 .schema: Obtener El Esquema De La Base De Datos
Instalando el programa para la línea de comandos 'sqlite3' puedes hacer muchas cosas.
Si lo ejecutas sin argumentos, funciona de forma interactiva, con un prompt que espera comandos.
Si lo ejecutas usando argumentos, puedes hacer algunas cosas interesantes como lo que pides:
Esto vuelca la estructura y el contenido a un fichero de texto:
Esto vuelca sólo la estructura:
Para volver a crear la base de datos a partir del fichero de texto se puede hacer así:
Para más información mira el manual de 'sqlite3 cli' en https://sqlite.org/cli.html porque si las bases de datos son muy grandes, se puede crear un fichero .gz comprimido al vuelo. Toda la info está en el manual.
Saludos
Si lo ejecutas sin argumentos, funciona de forma interactiva, con un prompt que espera comandos.
Si lo ejecutas usando argumentos, puedes hacer algunas cosas interesantes como lo que pides:
Esto vuelca la estructura y el contenido a un fichero de texto:
sqlite3 mibasededatos.db .dump >volcado_db_a_texto.sql
Esto vuelca sólo la estructura:
sqlite3 mibasededatos.db .schema >volcado_estructura_a_texto.sql
Para volver a crear la base de datos a partir del fichero de texto se puede hacer así:
cat volcado.sql | sqlite3 nueva.db
Para más información mira el manual de 'sqlite3 cli' en https://sqlite.org/cli.html porque si las bases de datos son muy grandes, se puede crear un fichero .gz comprimido al vuelo. Toda la info está en el manual.
Saludos
Objetivo: Re: SQLITE3 .schema: Obtener El Esquema De La Base De Datos
última edición por jsbsan el Martes, 23 Septiembre 2014, 08:59; editado 1 vez
Shordi:
Efectivamente, asi puedo obtener la información de las tablas y las vistas, en concreto extrayendo el campo "sql" se obtiene la información que necesito:
Jguardon:
Muy interesante lo que comentas.
Gracias a los dos.
Saludos
Julio
Efectivamente, asi puedo obtener la información de las tablas y las vistas, en concreto extrayendo el campo "sql" se obtiene la información que necesito:
Jguardon:
Muy interesante lo que comentas.
Gracias a los dos.
Saludos
Julio
última edición por jsbsan el Martes, 23 Septiembre 2014, 08:59; editado 1 vez
Objetivo: Re: SQLITE3 .schema: Obtener El Esquema De La Base De Datos
última edición por jsbsan el Martes, 23 Septiembre 2014, 20:27; editado 1 vez
Me he hecho un pequeño programa para obtener el esquema.
http://jsbsan.blogspot.com/2014/09/...e-de-datos.html
Puede ser interesante para aquellos que empiecen con bases de datos, ya que hacemos "lo tipico" en muy pocas lineas:
- conectarnos
- hacer la consulta
- guardar el resultado de la consulta en una variable
Saludos
http://jsbsan.blogspot.com/2014/09/...e-de-datos.html
Puede ser interesante para aquellos que empiecen con bases de datos, ya que hacemos "lo tipico" en muy pocas lineas:
- conectarnos
- hacer la consulta
hresult = hconn.Exec("SELECT sql From sqlite_master ")
- guardar el resultado de la consulta en una variable
Saludos
última edición por jsbsan el Martes, 23 Septiembre 2014, 20:27; editado 1 vez
Objetivo: Re: SQLITE3 .schema: Obtener El Esquema De La Base De Datos
Veo que al final te has desviado de la pregunta inicial, que era:
La solución era efectivamente el comando sqlite3 con algunos argumentos y un poco de la magia de bash, pero veo que al final has optado por una solución más "gambera".
Saludos
Citar:
La solución era efectivamente el comando sqlite3 con algunos argumentos y un poco de la magia de bash, pero veo que al final has optado por una solución más "gambera".
Saludos
Página 1 de 1
No puede crear mensajesNo puede responder temas
No puede editar sus mensajes
No puede borrar sus mensajes
No puede votar en encuestas
No puede adjuntar archivos
Puede descargar archivos
No puede publicar eventos en el calendario
Está utilizando la versión (Lo-Fi). Para ver la versión completa del foro, haga clic aquí.
Powered by Icy Phoenix based on phpBB
Design by DiDiDaDo
Página generada en:: 0.4388s (PHP: -78% SQL: 178%)
Consultas SQL: 47 - Debug off - GZIP Activado