• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

PDO - FROM zmienna - GET - bindValue

Object Storage Arubacloud
+1 głos
296 wizyt
pytanie zadane 17 maja 2016 w PHP przez niezalogowany

Witam, ćwiczę sobie korzystanie z PDO. Mam jednak ogromny problem z którym próbowałem się uporać już na wiele sposobów. Znakomicie działa mi funkcja bindValue - jeśli chcę wstawić jakąś zmienną do warunku WHERE. 

Jednak nie mogę sobie poradzić z wstawieniem zmiennej do zapytania, w którym tabela jest właśnie zmienną. Wygląda to tak:

$name = $_GET['name'];

require_once"baza.php";
			try{
				$db = new PDO('mysql:host='.$host.';dbname='.$db_name, $db_user, $db_password );
				echo 'Połączenie nawiązane!';
			}catch(PDOException $e){
				echo 'Połączenie nie mogło zostać utworzone';
			}

$stmt = $db->prepare('SELECT * FROM :name');
$stmt->bindValue(':name',$name,PDO::PARAM_STR);

	$stmt->execute();
									
	foreach($stmt as $row){
	     echo $row[nazwa_kolumny];
	}

 

Bardzo proszę o pomoc.

3 odpowiedzi

+3 głosów
odpowiedź 17 maja 2016 przez Comandeer Guru (601,110 p.)
Bo nazw tabel nie można wkładać jako parametry – je trzeba umieścić bezpośrednio w zapytaniu.

Tutaj najlepiej sprawdzi się whitelista.
komentarz 17 maja 2016 przez Mateusz821 Bywalec (2,940 p.)
BTW 'SELECT * ' jest złe
komentarz 17 maja 2016 przez Comandeer Guru (601,110 p.)
Bo…?
komentarz 17 maja 2016 przez niezalogowany
Comandeeer jak zwykle niezastąpiony jeśli chodzi o pomoc dla mnie. :) BTW to Ty pierwszy zwróciłeś mi uwagę żebym przestał używać mysql_*, a zainteresował się PDO lub mysqli. :)

 

Ta whitelist ma może jakąś inną nazwę? Bo nic konkretnego nie mogę znaleźć, a chciałem zrozumieć, a nie na skopiować kod z internetu i na chybił trafił dopasować do swojego kodu - aż zacznie działać. Znalazłem coś takiego tylko:

https://gist.github.com/wilmoore/2340119

http://stackoverflow.com/questions/13499390/variable-table-name-in-delete-sql-query-with-phps-pdo-safely
1
komentarz 17 maja 2016 przez Comandeer Guru (601,110 p.)
W sumie to, co znalazłeś, powinno się nadać. Whitelista to po prostu tablica dozwolonych wartości. Dzięki temu będzie można pobrać dane tylko z tabel, z których na to zezwolisz – a w innych wypadkach pobrać z domyślnej lub wywalić błąd ;)
komentarz 17 maja 2016 przez niezalogowany
Działa, wielkie dzięki! :)
komentarz 18 maja 2016 przez Paweł Chyła Użytkownik (560 p.)
Comandeer plusik dla ciebie za wyjaśnienie tematu,bo ja też za bardzo nie czaiłem co to jest ta whitelista :)
0 głosów
odpowiedź 17 maja 2016 przez Paweł Chyła Użytkownik (560 p.)
komentarz 17 maja 2016 przez niezalogowany
I nie bardzo rozumiem jak mam wykorzystać whitelisty do PDO. :/
0 głosów
odpowiedź 17 maja 2016 przez niezalogowany

Zrobiłem coś takiego, ale nadal nie działa:

​
$wartosc = 1;
									
									
																
		switch($wartosc)
				{
				case 1:
					$tabela = 'tabela_testowa';
					echo "test";
					break;
				}
									
		$sql = 'SELECT * FROM $tabela';
		$stmt = $db->prepare($sql);
										
									
		$stmt->execute();
									
		foreach($stmt as $row){
		echo $row[nazwa_kolumny];
		}						
komentarz 17 maja 2016 przez Ivan Maniak (60,650 p.)
Nie możesz dać $zmienna pomiędzy apostrofy, możesz to zrobić ale pomiędzy cudzysłowami.
komentarz 17 maja 2016 przez niezalogowany
Działa, wielkie dzięki! :)

Podobne pytania

0 głosów
1 odpowiedź 177 wizyt
pytanie zadane 11 stycznia 2021 w PHP przez WiktroH Mądrala (6,550 p.)
0 głosów
1 odpowiedź 229 wizyt
pytanie zadane 25 maja 2020 w PHP przez spicedagger Użytkownik (530 p.)
+1 głos
1 odpowiedź 242 wizyt
pytanie zadane 27 kwietnia 2022 w Python przez Hysek Obywatel (1,250 p.)

92,570 zapytań

141,422 odpowiedzi

319,643 komentarzy

61,958 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...