Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Zapytanie Mysql
Forum PHP.pl > Forum > Bazy danych > MySQL
ActivePlayer
mam w tablicy dane...
numery id które chce pobrac z mysqla
i teraz jak questionmark.gif

SELECT * FROM abc WHERE id="i co tutaj wstawic questionmark.gif"

chodzi o to zeby pobrac tylko te rekordy których id znam...
__phpion__
A co rozumiesz pod pojeciem 'znam'?
ActivePlayer
Ze moge je miec wypisane w dowolniej formie... jako tablica, w zmiennej oddzielone spacjami itd... zle napisalem

poprostu mam w zmiennej zapisane id tych rekordów które mam pobrac...
tiraeth
  1. <?php
  2. $Tablica[0] = 2141; // Pierwszy numer id
  3. $Tablica[1] = 4567; // Drugi numer id
  4. $Tablica[2] = 3432; // Trzeci numer id
  5. $Tablica[3] = 5675; // Czwarty numer id
  6. $Tablica[4] = 6724; // Piąty numer id
  7. // I tak dalej
  8.  
  9. // Ustawiamy początek zapytania i odrazu dodajemy do id pierwszy znany id
  10. $String = 'SELECT * FROM abc WHERE id='.$Tablica[0];
  11.  
  12. for($i=1; $i<count($Tablica); $i++)
  13. {
  14. $String .= ' OR id='.$Tablica[$i];
  15. }
  16.  
  17. // Poniżej dopisujemy dodatkowe atrybuty zapytania...
  18. // Koniecznie musi być na poczatku spacja
  19. $String .= ' ORDER BY id ASC';
  20. ?>


no i pętla for pododaje wszystkie id do zapytania i wtedy może ono wyglądać tak:
Cytat
SELECT * FROM abc WHERE id=2141 OR id=4567 OR id=3432 OR id=5675 OR id=6724 ORDER BY id ASC



oczywiście jeżeli masz to w zmiennej np. po przecinku to sobie explodujesz smile.gif chyba wiesz jak to się robi smile.gif
tumczasty
można też tak:
Cytat
SELECT * FROM abc WHERE id IN(2141,4567,3432,5675,6724) ORDER BY id ASC

a robi się to tak:
  1. <?php
  2. $Tablica=array(2141,4567,3432,5675,6724);
  3.  
  4. $String='SELECT * FROM abc WHERE id IN('.implode(',',$Tablica).')';
  5. ?>


a jak te wszystkie id są już w stringu oddzielone przecinkami (ew. spacjami --- patrz str_replace()), to prosta sprawa
ActivePlayer
ładne... tnks
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.