Provazani tabulek – MySQL – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

Provazani tabulek – MySQL – Fórum – Programujte.comProvazani tabulek – MySQL – Fórum – Programujte.com

 

radek pechak
~ Anonymní uživatel
2 příspěvky
15. 6. 2008   #1
-
0
-

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.

Nahlásit jako SPAM
IP: 84.19.69.–
Quiark0
Věrný člen
15. 6. 2008   #2
-
0
-

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.

Nahlásit jako SPAM
IP: 194.212.43.–
netman920
Super člen
15. 6. 2008   #3
-
0
-

ja by som to ulozil do jednej bunky
napr "uziv1:uziv2:uziv3";
a potom pomocou explode a list ich povezdzme vypisal a pod

Nahlásit jako SPAM
IP: 195.91.54.–
radek pechak
~ Anonymní uživatel
2 příspěvky
15. 6. 2008   #4
-
0
-

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.

Nahlásit jako SPAM
IP: 84.19.69.–
15. 6. 2008   #5
-
0
-

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!

Nahlásit jako SPAM
IP: 81.30.238.–
Prosím, jestli potřebujete s něčím poradit,zeptejte se na fóru. Jakýkoliv bezdůvodný pokus mě kontaktovat skončí okamžitým přidáním do ignore listu![br][br] Současný počet osob, které to nepochopily: 7
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 8 hostů

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

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032024 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý