Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> pobieranie danych z 2 tabel nawer jak ...
acztery
post
Post #1





Grupa: Zarejestrowani
Postów: 945
Pomógł: 7
Dołączył: 15.03.2005
Skąd: katowice

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


witam mam taki kłopot

mam 2 tabele

1. Nazwy
2. Wartosci przypisane do danej nazwy

i teraz chce wyswetlic wszystkie nazwy a obok och wartosci pobrane z tej 2 tabeli. Działa.
Ale jezeli w 2 tabeli nie ma danej wartosci dla danej nazwy, sama nazwa nie zostaje wyswetla a ja bym chcial aby byla wysetlona z tym ze byla by pusta.

mam takie zapytanie

  1. SELECT *
  2. FROM `forms` LEFT JOIN `forms_data` ON `forms_data`.`Id`=`forms`.`Id`
  3. WHERE ( forms_data.FromId = '1' ) AND ( forms_data.ParentId = 'test' ) GROUP BY forms.Id
Go to the top of the page
+Quote Post
prond
post
Post #2





Grupa: Zarejestrowani
Postów: 254
Pomógł: 10
Dołączył: 8.11.2006
Skąd: Warszawa

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


  1. SELECT
  2. *
  3. FROM `forms` LEFT OUTER JOIN `forms_data`
  4. ON `forms_data`.`Id`=`forms`.`Id`
  5. WHERE ( forms_data.FromId = '1' ) AND ( forms_data.ParentId = 'test' );


--------------------
--------------------------------------------------------------------------------
weblog.axent.pl
--------------------------------------------------------------------------------
Go to the top of the page
+Quote Post
acztery
post
Post #3





Grupa: Zarejestrowani
Postów: 945
Pomógł: 7
Dołączył: 15.03.2005
Skąd: katowice

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


to samo, dalej pokazuje tyle te reokry z 1 tabeli ktore maja wartosci w 2... sad.gif

taka struktura


  1. CREATE TABLE `forms` (
  2. `Id` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  3. `Name` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  4. `Label` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  5. `Type` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  6. `FromId` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  7. `Extra` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  8. `Ord` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  9. `Default_value` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  10. `Time` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  11. `Date` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  12. `Deleted` enum('N','Y') character SET utf8 collate utf8_polish_ci NOT NULL DEFAULT 'N',
  13. `Required` enum('N','Y') character SET utf8 collate utf8_polish_ci NOT NULL DEFAULT 'N',
  14. `FromName` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  15. PRIMARY KEY (`Id`)
  16. ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
  17.  
  18. -- --------------------------------------------------------
  19.  
  20. --
  21. -- Struktura tabeli dla `forms_data`
  22. --
  23.  
  24. CREATE TABLE `forms_data` (
  25. `Id` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  26. `ParentId` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  27. `FromId` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  28. `Time` varchar(255) character SET utf8 collate utf8_polish_ci NOT NULL,
  29. `value` text character SET utf8 collate utf8_polish_ci NOT NULL,
  30. PRIMARY KEY (`Id`)
  31. ) ENGINE=MyISAM DEFAULT CHARSET=utf8;


Ten post edytował acztery 15.03.2007, 13:32:33
Go to the top of the page
+Quote Post
Anna
post
Post #4





Grupa: Zarejestrowani
Postów: 11
Pomógł: 0
Dołączył: 21.11.2006

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


Nie wiem czy dobrze rozumiem, którą tabelę chcesz dołączyć. Może spróbuj tak:
  1. SELECT *
  2. FROM `forms_data` LEFT JOIN `forms` ON `forms_data`.`Id`=`forms`.`Id`
  3. WHERE ( forms_data.FromId = '1' ) AND ( forms_data.ParentId = 'test' ) GROUP BY forms.Id
Go to the top of the page
+Quote Post
acztery
post
Post #5





Grupa: Zarejestrowani
Postów: 945
Pomógł: 7
Dołączył: 15.03.2005
Skąd: katowice

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


jezeli w tabeli forms_data nie bedzie pola ParentId='test' to go ne wyswetli tzn jezeli user nie bedzie mial tego zdefiniowanego to kapa. a ja cehce aby bylo tylko np puste.

Ten post edytował acztery 15.03.2007, 14:05:18
Go to the top of the page
+Quote Post
Anna
post
Post #6





Grupa: Zarejestrowani
Postów: 11
Pomógł: 0
Dołączył: 21.11.2006

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


Jeśli chcesz wyświetlić wartość NULL z forms_data, to co robi w warunku WHERE forms_data.FromId = '1' AND forms_data.ParentId = 'test' questionmark.gif

Ten post edytował Anna 15.03.2007, 14:09:50
Go to the top of the page
+Quote Post
acztery
post
Post #7





Grupa: Zarejestrowani
Postów: 945
Pomógł: 7
Dołączył: 15.03.2005
Skąd: katowice

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


forms_data.FromId = '1' = id formularza z ktora ma wyswetlic rekordy
AND

forms_data.ParentId = 'test' = id uzytkownika dla ktore wyswetla rekordy.


łapatlogogicznie..



pobrane z

tabela 1 | tabela 2

kolor | zielony - wartosc zielony jest w tabeli form_data
--------------------------
rozmiar | duzy - tez jest
--------------------------
obudowa | - - nie ma


na tej podstawie wygeneruje sie formularz

uzytkownik w polu obudowa wpisze cos kliknie zapisze i wartosc sie zapleni dla dane usera i danego id froms
Go to the top of the page
+Quote Post
Anna
post
Post #8





Grupa: Zarejestrowani
Postów: 11
Pomógł: 0
Dołączył: 21.11.2006

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


może w ten sposób:

  1. SELECT * FROM `forms` LEFT JOIN (SELECT * FROM `forms_data` WHERE forms_data.FromId = '1' AND forms_data.ParentId = 'test' ) AS fd USING (Id)


Ten post edytował Anna 15.03.2007, 14:36:39
Go to the top of the page
+Quote Post
acztery
post
Post #9





Grupa: Zarejestrowani
Postów: 945
Pomógł: 7
Dołączył: 15.03.2005
Skąd: katowice

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


#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'Id`
LIMIT 0, 30' at line 1
Go to the top of the page
+Quote Post
Anna
post
Post #10





Grupa: Zarejestrowani
Postów: 11
Pomógł: 0
Dołączył: 21.11.2006

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


Spróbuj teraz
Go to the top of the page
+Quote Post
acztery
post
Post #11





Grupa: Zarejestrowani
Postów: 945
Pomógł: 7
Dołączył: 15.03.2005
Skąd: katowice

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


albo chyba jest ok ... dzieki jak by co dam znac

Ten post edytował acztery 15.03.2007, 14:39:46
Go to the top of the page
+Quote Post
Anna
post
Post #12





Grupa: Zarejestrowani
Postów: 11
Pomógł: 0
Dołączył: 21.11.2006

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


rozumiem, że masz w bazie rekordy spełniające warunek:

forms_data.FromId = '1' AND forms_data.ParentId = 'test'

tongue.gif
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 Aktualny czas: 19.08.2025 - 13:44