Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PHP][MySQL]Newsy
Forum PHP.pl > Forum > Przedszkole
newbie96
Temat do zamkniecia!
modern-web
Jeżeli w bazie danych masz zawarte kolumny z nazwą użytkownika to pewnie, że się da;
Niestety nie znam struktury Twojej tabeli dlatego jedyne co możesz zrobić to samemu potestować:
  1. echo '</td></table>    <small>Author:';

zamień na
  1. echo '</td></table>    <small>Author:';

i zobacz co się stanie smile.gif jedź po kolei numerami w tablicy $row (jeśli nie znasz struktury tabeli), a jeśli znasz to po prostu wstaw tam numer kolumny ;0

Pozdrawiam
newbie96
user_id to lucz obcy
modern-web
Rozumiem, że nazwa użytkownika znajduje się w tabeli `users`, tak? W takim wypadku musiałbyś zastosować LEFT JOIN smile.gif
newbie96
tak nazwa uzytkownika (username) znajduje sie w tabeli users

a jest jakis scrypt co zamienia user_id na username??
modern-web
Mylisz pojęcia... musisz stworzyć zapytanie do bazy danych, w którym połączysz obie tabele i wyciągniesz z tabeli users nazwę użytkownika na podstawie danych z tabeli news.
Przeczytaj początek tematu na tej stronie: http://www.w3schools.com/sql/sql_join_left.asp
Po pierwszym przykładzie wszystko zrozumiesz smile.gif
newbie96
Kod
SELECT
    n.*,
    u.username AS u
FROM
    `users` AS u
    JOIN news AS n ON u.user_id = n.user_id
ORDER BY
    username ASC,
    date ASC

teraz mi wyswietla nazwe uzytkownika tylko jak to na php zameinic ;d

modern-web
To co mi wysłałeś to zapytanie SQL... przypisz to do zmiennej, zastosuj funkcję query, zamień wynik na tablicę i odczytaj ją za pomocą $wynik[x] gdzie x będzie numerem kolumny (pamiętaj, że numerowanie kolumn w bazie danych zaczyna się od 0, nie od 1).
newbie96
Kod
$query = "SELECT n.*, u.username AS u FROM `users` AS u JOIN news AS n ON u.user_id = n.user_id ORDER BY username ASC, date ASC LIMIT 0, 30 ";

to zamiast tego:
Kod
$query = "SELECT titlle AS t, content AS c, user_id AS id FROM news ORDER BY date ASC LIMIT 0, 30 ";

tak?

ok problem rozwiazany!


dzieki modern-web
modern-web
  1. $zapytanie = "SELECT `username` FROM `users` LEFT JOIN `news` ON users.user_id = news.user_id";
  2. $query = mysql_query($zapytanie);
  3. while ($w = mysql_fetch_array($query)) {
  4. echo $w[X];
  5. }


Prototyp pisany od ręki, popraw i zobacz, czy działa. Teraz chyba wiesz co i jak...
newbie96
teraz chce zrobic ze jak nacisne nazwe autora newsa pokazuje mi jego dane: ile zrobil newsow , email itd. ale musze zrobic inny temat.


Dzieki !
modern-web
Nie ma sprawy, polecam się na przyszłość biggrin.gif
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.