Diskuze: Jak uložit stejné hodnoty u různých uživatelů
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 7 zpráv z 7.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Jméno je trošku zavádějící, ale pokud jsem to pochopil, tak tabulka videos obsahuje skladby. V principu se jedná o klasickou N:M relaci.....N uživatelů může mít tu stejnou skladbu a jeden uživatel může mít M skladeb. Lepší řešení, než máš v relačních databázích nevytvoříš. Budeš mít tabulku skladby_playlist
create table skladby_playlist (
skladba_id INTEGER,
playlist_id INTEGER,
FOREIGN KEY (skladba_id) REFERENCE videos(id),
FOREIGN KEY (playlist_id) REFERENCE playlists(id),
PRIMARY KEY (skladba_id,playlist_id)
)
Databáze je natolik chytrá, že si to přebere a optimalizuje. Nechal bych to tak.
Omlouvám se, ale nějak jsem nevěděl jak to co nejlépe popsat. Ale tvá odpověď mi zřejmě asi stačí a líbí se mi v tom, že to asi lépe nelze vymyslet v relační databázi.
Mohl by jsi mi ještě popsat co přesně dělá "FOREIGN" ve spojení "REFERENCE" ? anglicky tak dobře neumím a dokumentace mi tedy moc nepomohla. Ale předpokládám, že to částečně nahrazuje JOIN ?
S joinem a selectem to nemá co dělat, zajišťuje to podmínky pro hodnoty,
které v tabulce můžou být.
https://cs.wikipedia.org/…%C3%AD%C4%8D
To je cizí klíč. Ukazuje na primární klíč tabulky, se kterou máš
relaci. Předpokládám, že používáš MySQL
https://dev.mysql.com/…gn-keys.html
Takže řekneš, že chceš vytvořit cizí klíč FOREIGN KEY na nějakém sloupečku playlist_id, který odkazuje REFERENCE na primární klíč druhé tabulky playlist(id), s tím že ideálně specifikuješ, co se má stát, pokud se id v cizí tabulce smaže nebo změní (ON DELETE a ON UPDATE)
Takže kdybych provedl úpravu, dejme tomu změnil ID, tak se změna automaticky provede i v té referované ? Stejně tak, kyž dojde k smazání ?
Podle toho, jak si vybereš. Možnosti jsou opět v dokumentaci:
RESTRICT | CASCADE | SET NULL | NO ACTION | SET DEFAULT
Zobrazeno 7 zpráv z 7.