Insertar Un Registro En Sqlite En Una Tabla Que Usa Claves Foráneas [Solucionado]


Ir a la página 1, 2  Siguiente

Objetivo: 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.

última edición por tincho el Sabado, 10 Septiembre 2016, 16:16; editado 3 veces

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

Perfil MP  
Objetivo: 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.

Perfil MP  
Objetivo: 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.

Perfil MP  
Objetivo: 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.

Perfil MP  
Objetivo: 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

última edición por shordi el Miercoles, 07 Septiembre 2016, 18:13; editado 1 vez
Perfil MP  
Objetivo: 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/

Objetivo: 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.

Perfil MP  
Objetivo: 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.

Perfil MP  
Objetivo: 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

Perfil MP  
Objetivo: 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.

Perfil MP  
Ir a la página 1, 2  Siguiente

Página 1 de 2


  
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

   

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.1479s (PHP: -48% SQL: 148%)
Consultas SQL: 33 - Debug off - GZIP Activado