Diskuze: Dotaz zkrze více tabulek - JOIN
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 8 zpráv z 8.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
comment.user_id = 1 -- vsude pridavas uzivatele 1, takze ocekavas co?
Buď jsi nepochopil, k čemu slouží JOIN, nebo já nechápu, čeho se
snažíš docílit...
Podle mě by zápis JOIN měl být nějak takto:
JOIN user on comment.user_id = user.uset_id
I toto jsem zkoušel, ale pořád to blbne, vypíše to danou osobu i v případě že u dané položky osoba není.
Snažím se docílit tohoto. Dvě tabulky v jedné jsou uživatelé a v druhé komentáře. U komentářů se místo jména ukládá jen zástupný znak, v tomto případě číslo které přesně koresponduje se jménem uživatele. V šabloně následně pomocí rekurze vypisuji komentářes spolu s dalšímu daty. vše se vypisuje jak má až na toto.
V phpmyadmin, jsem zkoušel různé varianty. Buď nastalo to že se ke všem komentářům přiřadil poslední uživatel, nebo cyklicky všechni uživatelé, tj v databázi jsou tři uživatelé a ti se cyklicky opakovali u všech příspěvků a nebo se mi zobrazí když zadám id uživatele tak opět daný uživatel u všech komentářů.
Tak dobře, teď zda mohu poprosit o vysvětlení.
Kód zustal prakticky beze změny jediné co jsem udělal bylo to že jsem JOIN upravil takto
INNER JOIN user ON user.user_id = comment.user_id
Pokud se nepletu tak, JOIN se standartně, vykládá jako INNER JOIN. Nebo se pletu? Používám Maria DB
Ano, standardně je inner. Zkus nedávat do dotazu hvězdičku, ale vypiš sloupce, které chceš zobrazit
Select comment.neco, comment.necojineho, user.jmeno, user.prijmeni from comment join...
Jo tohle už jsem udělal, obecný jsem to měl jen pro testovací účely. Protože jsem to v phpmyadminovy napsal dohromady dost možná 30x a nechtělo se mi to vypisovat vše, dokud mi to nepůjde tak jak si představuju. Každopádně díky.
LEFT JOIN? Mas to v tom odkaze.
Zobrazeno 8 zpráv z 8.