Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [MySQL]Wybieranie z MSQL query
zyznos321
post 13.05.2013, 19:22:12
Post #1





Grupa: Zarejestrowani
Postów: 27
Pomógł: 0
Dołączył: 17.12.2011

Ostrzeżenie: (0%)
-----


Mam następujący problem:
Chcę wybrać z bazy danych wszystkie wiersze, których odpowiednik w drugiej "tabeli" (o takim samym id) ma zmienną firma różną od "test". W tym celu wywołuje nastepujące zapytanie:

  1. $wynik = mysql_query("select first.*, second.* from ".$dbWykonane." first LEFT JOIN ".$dbNazwy." second ON first.akcja = second.id where second.firma<>'test' and first.user='"22"' and first.wzrost='tak' "."order by first.id desc");


Niestety niektóre wiersze nie posiadają swoich odpowiedników w $dbNazwy, a je także chciałbym pobrać (bez względu jaki mają second.firma, ponieważ wcale go nie mają). Jak powinienem sformułować zapytanie?

Ten post edytował zyznos321 13.05.2013, 19:23:24
Go to the top of the page
+Quote Post
nospor
post 13.05.2013, 21:01:08
Post #2





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




LEFT JOIN jest jak najbardziej do tego OK. W czym problem?


--------------------

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post
zyznos321
post 14.05.2013, 06:20:57
Post #3





Grupa: Zarejestrowani
Postów: 27
Pomógł: 0
Dołączył: 17.12.2011

Ostrzeżenie: (0%)
-----


Problem w tym, że nie wszystkie wiersze mają swoje odpowiedniki, a je także chciałbym wybrać. Wszystkie wiersze posiadają kolumnę first.akcja ale nie wszystkie posiadają odpowiednik second.id w drugiej tabeli i nie są wyświetlane.
Go to the top of the page
+Quote Post
nospor
post 14.05.2013, 07:04:40
Post #4





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




Skoro nie zawsze będzie second, to nie możesz w warunku robić lecieć po second...
where second.firma<>'test'
To nie moze być w WHERE. To musi być w LEFT JOIN

..... LEFT JOIN ".$dbNazwy." second ON (first.akcja = second.id and second.firma<>'test')......


--------------------

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 13.06.2025 - 02:29