Dobry den,
mel by jsem dotaz ohledne provazani tabulek v mysql databazi.
Uvedu priklad:
mam tabulku uzivatelu a chtel by jsem aby si jednotlivi uzivatele mohli pridavat jine uzivatele mezi sve pratele.
U kazdeho uzivatele mam jedinecne ID uzivatele, ale nevim jak vytvorit jednoduse to, ze bude mit jeden uzivatel treba 400 pratel co nejednoduseji tak, aby jsem nemusel do dalsi tabulky ukladat vsechny ID uzivatelu, ktere ma mezi prateli.
Doufam ze je z toho pochopitelne, jak je to mysleno.
Diky.
Fórum › MySQL
Provazani tabulek
Standardní postup je vytvoření vazebné tabulky, kde budou dva sloupce, oba budou id uživatele. V tabulce bude řádek (a, b) právě tehdy, když uživatel a má známého b. Jestli to bude symetrické si musíš rozhodnout sám :) Tato struktura se pak dá použít ve spojení s JOINy.
To Quiark : Diky. nad timto zpusobem jsem taky uvazoval a nakonec jej asi pouziju.
To netman92 : Tento zpusob se mi moc nezamlouva. Jde o to ze je potom dost problematicke zjistit, jestli jeden dany uzivatel patri mezi pratele. Musel by jsi vybirat pomoci LIKE cemuz by jsem se chtel vyhnout, nebo to zpracovavat az na strane serveru coz neni v tomto pripade moc efektivni.
Jezismarija, vzdyt tohle je jeden ze zakladnich principu trosicku slozitejsich databazi! Rika se tomu n:n spojeni a dela se to presne tak jak napsal Quiark. Vytvoris si tabulku se dvema sloupci (treba user_id_1 a a user_id_2 a oba das jako primary). Pak uz to jen budes cist pomoci joinu/left joinu (na to si najdi nejaky tut).
Jestli chces zjistit, jestli je user 17 kamarad usera 29 tak udelas tohle:
SELECT 1 FROM friends WHERE user_id_1=17 AND user_id_2=29
A na vypsani vsech kamaradu usera 17 tohle
SELECT users.name FROM friends JOIN users WHERE friends.user_id_1=17 AND users.id=friends.user_id_2
A pro vypsani vsech useru a jejich kamaradu tohle
SELECT users1.name AND users2.name FROM users AS users1 LEFT JOIN friends ON (user1.id=friends.user_id1) JOIN users AS users2 WHERE user2.id=friends.user_id2
A jedna za zakladnich poucek o databazich:
Nikdy neukladej vic ruznych dat do jedne bunky!
Přidej příspěvek
Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku
×Vložení zdrojáku
×Vložení obrázku
×Vložení videa
Uživatelé prohlížející si toto vlákno
Podobná vlákna
Spojení tabulek — založil Paja2
Slučovnání tabulek — založil Mergl
Seznam tabulek — založil ProgDan
Linkování tabulek — založil Toka
Moderátoři diskuze