Portal    Foro    Buscar    FAQ    Registrarse    Conectarse


Publicar nuevo tema  Responder al tema 
Página 1 de 2
Ir a la página 1, 2  Siguiente
 
Insertar Un Registro En Sqlite En Una Tabla Que Usa Claves Foráneas [Soluc...
Autor Mensaje
Responder citando   Descargar mensaje  
Mensaje Insertar Un Registro En Sqlite En Una Tabla Que Usa Claves Foráneas [Solucionado] 
 
Hola seguramente esto esta explicado en alguna parte de este foro, pero no logre encontrarlo.

Hice una base de datos de música en sqlite3 que se encuentra relacionada mediante indices, y ahora intento insertar un registro en una vista, de tal manera que le diga los valores de los campos en forma de "texto" y que la base se busque la vida para insertar un "entero" que es el indice de ese texto en otra tabla.
La teoría todo fenómeno, pero no funciona.

Alguien podría decirme que estoy haciendo mal o que me falta configurar, y aun mejor como es la sentencia de insercion SQL.

Adjunto la base y un diagrama de como esta relacionada.

sentencia sql de la vista

SELECT
trackindx,
tracktitle,
tracknum,
albumname AS trackalbum,
artistname AS trackartist,
genrename AS trackgenre,
trackyear,
typename AS tracktype

FROM track

LEFT JOIN  album ON trackalbum=albumindx
LEFT JOIN  artist ON trackartist=artistindx
LEFT JOIN  genre ON trackgenre=genreindx
LEFT JOIN  type ON tracktype=typeindx
 


Saludos y gracias.

dbmusica.zip
Descripción:  
Descargar
Nombre del archivo: dbmusica.zip
Tamaño: 18.6 KB
Descargado: 89 veces
dbmusica.zip
Descripción:  
Descargar
Nombre del archivo: dbmusica.zip
Tamaño: 18.6 KB
Descargado: 89 veces
dbmusica.zip
Descripción:  
Descargar
Nombre del archivo: dbmusica.zip
Tamaño: 18.6 KB
Descargado: 89 veces

 



 
última edición por tincho el Sabado, 10 Septiembre 2016, 16:16; editado 3 veces 
tincho - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: Insertar Un Registro En Sqlite En Una Vista 
 
Citar:
como es la sentencia de insercion SQL.


Tal sentencia no existe. Una vista es lo que su nombre indica: Una Vista. Una forma de ver los registros "esparcidos" en varias tablas y/o formateados de manera más "visual".

Una vista no se actualiza. Sólo se "ve".

Tienes que insertar/modificar/eliminar los registros en sus tablas correspondientes.

Saludos.
 




===================
No podemos regresar
 
shordi - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: Insertar Un Registro En Sqlite En Una Vista 
 
ok, vale voy a hacer la pregunta de otra manera.

En el ejemplo hay una tabla principal llamada tracks (canciones) donde hay campos como artista o álbum, pero estos son campos que están relacionados mediante una clave foránea con otras tablas.
¿Como puedo insertar registros en tracks y si por ejemplo no existe un álbum que sqlite cree ese álbum en la tabla albums y en la tabla tracks se ponga ese indice nuevo correspondiente?

Saludos.
 



 
tincho - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: Insertar Un Registro En Sqlite En Una Vista 
 
estimado tincho.

lo que dice shordi es correcto, una vista es solo una capa de una serie de tablas reales.. por lo que si lo que deseas es que te "aparezca" un registro nuevo en la vista "track" debes crear el set de registros en todas las tablas que mencionas en tu query, de lo contrario podrás esperar sentado tomando un rico café para que esto ocurra por arte de magia. Ahí te toca trabajar en los insert de cada uno de ellos.
 



 
chaskux - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: Insertar Un Registro En Sqlite En Una Vista 
 
Citar:
¿Como puedo insertar registros en tracks y si por ejemplo no existe un álbum que sqlite cree ese álbum en la tabla albums y en la tabla tracks se ponga ese indice nuevo correspondiente?

Con un proceso de gambas. SQLite no puede hacer eso por tí. La integridad referencial se ocupa de que todas las referencias que existan en la base de datos sean correctas. Es decir, que si tú pones que esto es de tal album, tal album exista. Pero no puede crear las referencias. Tú, en tu proceso de gambas, eres quien primero ha de comprobar si el álbum existe, crearlo si no es así y luego añadir las pistas.
Hay varias formas de hacerlo.

Una es:

1.- Almacenar en un combobox todos los álbumes del artista (o todos a lo bestia, como desees)
2.- Si el album existe lo seleccionas y punto
3.- Si no existe lo tecleas y entonces, en el evento lostfocus, por ejemplo, del combobox  compruebas si lo tecleado está en la lista y si no, lo añades a la tabla
4.- Cuando llega el momento de grabar la pista ya tienes el álbum disponible.

Inconveniente: si tecleas el álbum pero no grabas la pista tienes un álbum vacío...(cosa que puede ser buena o mala, según depende)

Otra es dejar toda la tarea al proceso de grabar, que

1.- Comprueba si la propiedad .text del combobox es un elemento de la lista y si no lo es
2.- Crea el álbum y
3.- Graba la pista

Inconveniente... no se me ocurre ninguno importante salvo unos milisengundos usados en comprobaciones...

Saludos
 




===================
No podemos regresar
 
última edición por shordi el Miercoles, 07 Septiembre 2016, 18:13; editado 1 vez 
shordi - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: Insertar Un Registro En Sqlite En Una Vista 
 
tincho:

Citar:
en la tabla tracks se ponga ese indice nuevo correspondiente?

Añadiendo lo que te comenta Shordi, para saber los datos del último registro introducido (por ejemplo su indice), hay varias formas de obtenerlo:

select * from tabla order by id DESC limit 1

(obtenemos un result con todos los campos del registro último introdudido)

o

SELECT MAX(id) FROM tabla

(obtenemos un result, con el numero mayor de id)


Nota:
siempre que el campo "id" sea autoincremental

Fuente:
http://www.forosdelweb.com/f18/obte...o-mysql-671592/
 




===================
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: Insertar Un Registro En Sqlite En Una Vista 
 
shordi escribió: [Ver mensaje]
Con un proceso de gambas. SQLite no puede hacer eso por tí. La integridad referencial se ocupa de que todas las referencias que existan en la base de datos sean correctas. Es decir, que si tú pones que esto es de tal album, tal album exista. Pero no puede crear las referencias. Tú, en tu proceso de gambas, eres quien primero ha de comprobar si el álbum existe, crearlo si no es así y luego añadir las pistas.
Hay varias formas de hacerlo.

Si, exacto por ahí van los tiros, pero lo que estoy queriendo hacer es un programa que pueda "alimentar" una base de datos a medida que le son pasados archivos con meta datos, por ejemplo .ogg.
Lo que hacen todos los programas de colecciones de música, digamos.
Pero creo que ya tengo los conceptos asimilados   asi que ye les contare como fue la cosa en unos...¿dias?
Gracias por la ayuda.
Saludos.
 



 
tincho - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: Insertar Un Registro En Sqlite En Una Vista 
 
jsbsan escribió: [Ver mensaje]
select * from tabla order by id DESC limit 1
(obtenemos un result con todos los campos del registro último introdudido)
o
SELECT MAX(id) FROM tabla
(obtenemos un result, con el numero mayor de id)
siempre que el campo "id" sea autoincremental

Gracias, creo que este tipo de sentencias SQL sera útil para agregar registros en las tablas accesorias y principal.
Saludos.
 



 
tincho - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: Insertar Un Registro En Sqlite En Una Tabla Que Usa Claves Foráneas 
 
Citar:
Si, exacto por ahí van los tiros, pero lo que estoy queriendo hacer es un programa que pueda "alimentar" una base de datos a medida que le son pasados archivos con meta datos, por ejemplo .ogg.
Lo que hacen todos los programas de colecciones de música, digamos.

Buff... olvídate entonces de la integridad referencial. Si tu fuente de datos son archivos creados por otras personas con sus propios criterios y maneras de teclear los datos, es imposible que cuadres y sistematices todo de manera perfecta.
Alguien puede catalogar que "Money" pertenece a "The Dark Side of the Moon" y alguien puede catalogar que pertenece a "Dark Side of the Moon, The"
Imposible predecir todo eso, imposible establecer las referencias de manera coherente.

Ahí, me temo, te toca "tragar" todo lo que los archivos de metadatos te cuenten y luego, a lo sumo, establecer en tu programa procedimientos para "corregir" los datos. Algo así como "Cambiar todas las pistas que pertenezcan al álbum tal por el álbum cual" y "Borrar álbumes sin pistas", etc. etc.

Saludos
 




===================
No podemos regresar
 
shordi - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Responder citando   Descargar mensaje  
Mensaje Re: Insertar Un Registro En Sqlite En Una Tabla Que Usa Claves Foráneas 
 
shordi escribió: [Ver mensaje]
...todo lo que los archivos de meta datos te cuenten y luego, a lo sumo, establecer en tu programa procedimientos para "corregir" los datos. Algo así como "Cambiar todas las pistas que pertenezcan al álbum tal por el álbum cual" y "Borrar álbumes sin pistas", etc. etc.

Si pensaba hacer algo así para cargar todo, pero cuando algo no cuadre en el momento de la carga here un formulario que muestre el disco y junto a cada dato que no cuadre algunas sugerencias para elegir, y tener una tabla de "aprendizaje" que cuando encuentre "tal cosa" a la base suba Tal Cosa".

Saludos.
 



 
tincho - Ver perfil del usuarioEnviar mensaje privado 
Volver arribaPágina inferior
Mostrar mensajes anteriores:    
 
OcultarTemas parecidos
Tema Autor Foro Respuestas último mensaje
No hay nuevos mensajes Problema Al Seleccionar Un Registro De La ... Cubel Bases de Datos 5 Martes, 19 Enero 2010, 22:13 Ver último mensaje
Cubel
No hay nuevos mensajes Insertar Un Registro En Una Tabla Con Sqli... Shell Bases de Datos 3 Jueves, 21 Julio 2011, 08:38 Ver último mensaje
shordi
No hay nuevos mensajes Error Al Agregar Registro Sea En Sqlite O ... jousseph Bases de Datos 5 Martes, 28 Agosto 2012, 12:34 Ver último mensaje
jsbsan
No hay nuevos mensajes Sqliteman Y Las Claves Foráneas tincho Bases de Datos 2 Viernes, 09 Septiembre 2016, 15:10 Ver último mensaje
tincho
 

Publicar nuevo tema  Responder al tema  Página 1 de 2
Ir a la página 1, 2  Siguiente

Usuarios navegando en este tema: 0 registrados, 0 ocultos y 1 invitado
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