Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: wyszukiwanie 3 pól,
Forum PHP.pl > Forum > Przedszkole
tiramizu
Witam wszystkich. Jestem początkujący, i mam taki problem, z którym się zmagam jakiś okres czasu.
Mam trzy parametry do zapytania SQL-owego.
POST [f]
POST [m]
POST [p]
W zależności co jest wpisane, php powinien przekierować do zapytania SQL.
Możliwości są takie:
1. $sql="select * from baza where magazyn LIKE \"$_POST[f]\"" ;
2. $sql="select * from baza where asortyment LIKE \"$_POST[m]\"" ;
3. $sql="select * from baza where magazyn LIKE \"$_POST[f]\" and asortyment LIKE \"$_POST[m]\"" ;
4. $sql="select * from baza where towar LIKE \"$_POST[p]\" " ;
5. $sql="select * from baza where magazyn LIKE \"$_POST[f]\" and towar LIKE \"$_POST[p]\" " ;
6. $sql="select * from baza where asortyment LIKE \"$_POST[m]\" and towar LIKE \"$_POST[p]\"" ;
7. $sql="select * from baza where magazyn LIKE \"$_POST[f]\" and asortyment LIKE \"$_POST[m]\" and towar LIKE \"$_POST[p]\" " ;
W skrócie:
1. SQL f
2. SQL m
3. SQL f, m
4. SQL p
5. SQL f, p
6. SQL m, p
7. SQL f, m, p
Proszę o podpowiedź, zakręciłam się już w tych pętlach.
Dziękuję.
gladiror
Cytat
W zależności co jest wpisane, php powinien przekierować do zapytania SQL.


Co to znaczy?

Co moze byc wpisane pod:

POST [f]
POST [m]
POST [p]

questionmark.gif

Jeżeli dobrze zrozumiałem to chyba chodzi o to, ze jeżeli jedno pole jest puste z tych 3-ech to ma tamte 2 dodac a trzeciego nie. Jeżeli o to chodzi to musisz użyć funkcji if, np.

  1. <?php
  2. if($_POST['f']<>'')
  3. {
  4. /*instrukcja*/
  5. }
  6. ?>


Dla punktu 5:
  1. <?php
  2. if(($_POST['f']<>'') and ($_POST['p']<>''))
  3. {
  4. /*instrukcja*/
  5. }
  6. ?>


I podobnie dla reszty..
kossa
Napisz dokładnie jaki jest problem, bo teraz to można strzeleć i kombinować o co Tobie chodzi, zabrakło pytania oraz temat postu jest mało mówiący...

Jeśli masz problem tylko z ustalaniem, które z zapytań wywołać na podstawie zawartości zmiennej przesłanej za pomoca formularza metodą post to tak jak napisał Gladiror skorzystaj np. z
instrukcji sterującej if else else if"
Pozdrawiam,
Łukasz
Kosmi
Jeżeli dobrze zrozumiałem to chodzi Ci o coś takiego

  1. <?php
  2. $sql="select * from baza " ;
  3.  
  4. if(!empty($_POST['f']) || !empty($_POST['m']) || !empty($_POST['p'])){
  5. $sql.="where ";
  6. if(!empty($_POST['f'])){
  7. $sql.="magazyn LIKE '".$_POST['f']."' ";
  8. };
  9. if(!empty($_POST['m'])){
  10. if(!empty($_POST['f'])){
  11. $sql.="AND ";
  12. }
  13. $sql.="asortyment LIKE '".$_POST['m']."' ";
  14. };
  15. if(!empty($_POST['p'])){
  16. if(!empty($_POST['f']) || !empty($_POST['m'])){
  17. $sql.="AND ";
  18. }
  19. $sql.="towar LIKE '".$_POST['p']."' ";
  20. };
  21. }
  22. ?>



Pozdrawiam
Athlan
Cytat
1. $sql="select * from baza where magazyn LIKE \"$_POST[f]\"" ;


hmmm, a nie czasem:

Kod
1. $sql="select * from baza where magazyn LIKE \"$_POST['f']\"";
nospor
@Athlan jak juz chcesz sie wykazac wiedzą i kogoś poprawić to sprawdź, czy oby na pewno ty masz rację. Otoż Twoj sposob wywali parse errory, a sposob ktory poprawiales jest jak najbardziej poprawny.
Zanim zadasz pytanie: "Dlaczego?"
Odsylam cię do manuala w celu poszukania dlaczego smile.gif
tiramizu
Już tłumaczę dokładnie, o co mi chodzi:
Ma to działać podbnie jak http://www.ditel.com.pl/index.php?kbi=1063...t%F3w+biurowych.
Czyli użytkownik chcąc wyszukać coś w bazie może podać takie informacje:

Pokaż mi wszystko co się znajduję w magazynie 1:
I na przykład wyświetli mu się np. 1000 rekordów.
$sql="select * from baza where magazyn LIKE \"$_POST[f]\"" ;

Ale może podać bardziej szczegółowe dane, np.
Pokaż mi wszystko co się znajduję w magazynie 1 i jest z firmy Ziaja
$sql="select * from baza where magazyn LIKE \"$_POST[f]\" and asortyment LIKE \"$_POST[m]\"" ;

Ale może podać np wyświetl mi wszystko z firmy Ziaja i mają to być tylko kremy.
$sql="select * from baza where asortyment LIKE \"$_POST[m]\" and towar LIKE \"$_POST[p]\"" ;

Mój problem polega na tym, że nie wiem jak zrobić w php aby w zależności od podanych informacji, i ilości, php przekierował na odpowiednie zapytanie SQL. Mam nadzieję że teraz dobrze wytłumaczyłam zagadnienie.
nospor
No to dostales odpowiedź pare postow wyżej, aczkolwiek troche zamotaną. Tu masz bardziej uniwersalnie:
http://forum.php.pl/index.php?showtopic=36...mp;#entry204618

1) popraw tytul na mowiący cośo tresci

2)
proszę poprawić tytuł o znacznik zgodnie z zasadami forum Przedszkole:
Temat: Tematyka i zasady panujace na forum Przedszkole


3) uzywaj bbcode!!!
Athlan
@nospor: wiem DLACZEGO smile.gif a dlaczego to jest taka gazeta...

sory zapomniałem się, miało być:

Kod
$sql="select * from baza where magazyn LIKE \"".$_POST['f']."\"";
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.