Portal    Foro    Buscar    FAQ    Registrarse    Conectarse


Publicar nuevo tema  Responder al tema 
Página 1 de 1
 
 
SQLITE3 .schema: Obtener El Esquema De La Base De Datos
Autor Mensaje
Responder citando   Descargar mensaje  
Mensaje SQLITE3 .schema: Obtener El Esquema De La Base De Datos 
 
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ú:
 pantallazo_sqlite_manager_home_minino_prueba_sqlite
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.
 




===================
Blog personal
Web: SoloGambas seleccion de articulos dedicados a Gambas
Visita el Curso de Gambas3 ¡¡¡Gratuito!!!
 
jsbsan - Ver perfil del usuarioEnviar mensaje privadoVisitar sitio web del usuario 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje 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
select * from sqlite_master

es suficiente.

Saludos.
 



 
shordi - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje 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:
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
 




===================
Jesús Guardón

Por favor, usemos el corrector ortográfico antes de pulsar el botón "Enviar".

"uo ǝs ʇɐu pıɟıɔıן ɐdɹǝupǝɹ ɐ dɹoƃɹɐɯɐɹ, soןo ɥɐʎ bnǝ dɹodouǝɹsǝןo"
 
jguardon - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: SQLITE3 .schema: Obtener El Esquema De La Base De Datos 
 
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:

SELECT sql FROM sqlite_master



Jguardon:

Muy interesante lo que comentas.

Gracias a los dos.

Saludos

Julio
 




===================
Blog personal
Web: SoloGambas seleccion de articulos dedicados a Gambas
Visita el Curso de Gambas3 ¡¡¡Gratuito!!!
 
última edición por jsbsan el Martes, 23 Septiembre 2014, 08:59; editado 1 vez 
jsbsan - Ver perfil del usuarioEnviar mensaje privadoVisitar sitio web del usuario 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: SQLITE3 .schema: Obtener El Esquema De La Base De Datos 
 
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

'abrir base de datos
hconn.host = TextBoxRuta.Text
hconn.Name = TextBoxRuta.Text
hconn.Type = "Sqlite3"
Try hconn.Open()
If Error Then
Message.Error("Se ha producido un error al intentar leer la base de datos")
Return
Endif
 


- hacer la consulta


hresult = hconn.Exec("SELECT sql From sqlite_master ")


- guardar el resultado de la consulta en una variable
....
While hresult.Available
'vamos almacenando el resultado de cada registro en la variable "contenido"
contenido &= hresult["sql"] & gb.NewLine
hresult.MoveNext
Wend
....
 



Saludos
 




===================
Blog personal
Web: SoloGambas seleccion de articulos dedicados a Gambas
Visita el Curso de Gambas3 ¡¡¡Gratuito!!!
 
última edición por jsbsan el Martes, 23 Septiembre 2014, 20:27; editado 1 vez 
jsbsan - Ver perfil del usuarioEnviar mensaje privadoVisitar sitio web del usuario 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: SQLITE3 .schema: Obtener El Esquema De La Base De Datos 
 
Veo que al final te has desviado de la pregunta inicial, que era:

Citar:
Pregunta ¿hay una forma de hacer un script en bash para que esa información la pase a un archivo de texto plano?


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
 




===================
Jesús Guardón

Por favor, usemos el corrector ortográfico antes de pulsar el botón "Enviar".

"uo ǝs ʇɐu pıɟıɔıן ɐdɹǝupǝɹ ɐ dɹoƃɹɐɯɐɹ, soןo ɥɐʎ bnǝ dɹodouǝɹsǝןo"
 
jguardon - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: SQLITE3 .schema: Obtener El Esquema De La Base De Datos 
 
jguardon:

Citar:
al final has optado por una solución más "gambera".

Si, porque pense que con gambas no se podia hacer.... pero se puede  
 




===================
Blog personal
Web: SoloGambas seleccion de articulos dedicados a Gambas
Visita el Curso de Gambas3 ¡¡¡Gratuito!!!
 
jsbsan - Ver perfil del usuarioEnviar mensaje privadoVisitar sitio web del usuario 
Volver arribaPágina inferior
Mostrar mensajes anteriores:    
 
OcultarTemas parecidos
Tema Autor Foro Respuestas último mensaje
No hay nuevos mensajes Conectar Y Obtener Datos De Una BD SQLITE DEATH Bases de Datos 4 Viernes, 29 Julio 2011, 03:31 Ver último mensaje
jousseph
No hay nuevos mensajes Como Obtener Datos Del Textbox maickolmedina General 4 Miercoles, 13 Marzo 2013, 17:24 Ver último mensaje
datobinario
No hay nuevos mensajes Esquema De Guardado De Datos Unico drjuano Aplicaciones/Fragmentos de Código 5 Martes, 02 Abril 2013, 10:01 Ver último mensaje
Shell
No hay nuevos mensajes Esquema O Resumen De Aplicación Con Una B... Shell Bases de Datos 5 Martes, 07 Enero 2014, 20:42 Ver último mensaje
shordi
 

Publicar nuevo tema  Responder al tema  Página 1 de 1
 

Usuarios navegando en este tema: 0 registrados, 0 ocultos y 0 invitados
Usuarios registrados conectados: Ninguno


 
Lista de permisos
No puede crear mensajes
No 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



  

 

cron