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


Goto page 1, 2  Next

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

Last edited by tincho on Saturday, 10 September 2016, 16:16; edited 3 times in total

dbmusica.zip
Description:  
Download
Filename: dbmusica.zip
Filesize: 18.6 KB
Downloaded: 97 Time(s)
dbmusica.zip
Description:  
Download
Filename: dbmusica.zip
Filesize: 18.6 KB
Downloaded: 97 Time(s)
dbmusica.zip
Description:  
Download
Filename: dbmusica.zip
Filesize: 18.6 KB
Downloaded: 97 Time(s)

Profile PM  
Subject: 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.

Profile PM  
Subject: 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.

Profile PM  
Subject: 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.

Profile PM  
Subject: 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

Last edited by shordi on Wednesday, 07 September 2016, 18:13; edited 1 time in total
Profile PM  
Subject: 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/

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

Profile PM  
Subject: 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.

Profile PM  
Subject: 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

Profile PM  
Subject: 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.

Profile PM  
Goto page 1, 2  Next

Page 1 of 2


  
You cannot post new topics
You cannot reply to topics
You cannot edit your posts
You cannot delete your posts
You cannot vote in polls
You cannot attach files
You can download files
You cannot post calendar events

   

This is a "Lo-Fi" version of our main content. To view the full version with more information, formatting and images, please click here.

Powered by Icy Phoenix based on phpBB
Design by DiDiDaDo

Generation Time: 0.0971s (PHP: -27% SQL: 127%)
SQL queries: 26 - Debug Off - GZIP Enabled