Diskuze: Filtrování SQL dotazu pomocí několika checkboxů
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 6 zpráv z 6.
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
$filtry = array(
'pohlavi' => array(),
'velikost' => array()
);
$where = array();
foreach ($filtry as $key=>$values)
{if (is_array($values) && count($values)) {
$values = array()
foreach($values as $index=>$value)
$values[$index] = escapeValue($value);
$where[] = escapeKey($name).' IN ('.implode(',', $values).')'
}}
$where = implode(' AND ', $where);
Dobre je, ze si tam muzes dat podminku na filter name a udelat mu slesl obsah pro where.
Můžu se zeptat, co dělá ta funkce escapeValue a escapeKey? Kódu totiž do tohoto bodu rozumím, použil jsem var_dump a vždy do té chvíle něco vypsal, ale když následně vypíšu var_dump($values), tak je prázdný. Posílám ještě pro jistotu kód, jak jsem ho aplikoval...
if (isset($_GET["pohlavi"]))
$pohlavi = $_GET["pohlavi"];
else
$pohlavi = ["muz", "zena"];
if (isset($_GET["velikost"]))
$velikost = $_GET["velikost"];
else
$velikost = ["maly", "stredni","velky"];
$filtry = array(
'pohlavi' => $pohlavi,
'velikost' => $velikost );
//var_dump($filtry);
$where = array();
foreach ($filtry as $key=>$values) {
if (is_array($values) && count($values)) {
$values = array();
foreach ($values as $index=>$value) {
$values[$index] = escapeValue($value);
var_dump($values);
}
$where[] = 'IN ('.implode(',', $values).')';
}
}
Předem díky
No, ty escape, to si doplnis podle sveho sql. Aby to nenarusilo sql dotaz. Treba pro mysql je
escapekey = "`". $key . "
`" // a jeste z key odstranit znaky,
ktere pro nazev sloupce/tabulky nelze pouzit
escapeValue = . "'". mysql_real_escape_string($value). "'"
https://dev.mysql.com/…iterals.html
https://www.php.net/…e-string.php
Ps. A ten kod mas uplne spatne. Zkus nad tim premyslet, co jsem se pokusil
napsat.
>> $values = array();
Paráda, moc díky za popostrčení! Podařilo se mi to zprovoznit, kód vypadá následovně:
$filtry = array(
'pohlavi' => $pohlavi,
'velikost' => $velikost );
$where = array();
foreach ($filtry as $key=>$values) {
if (is_array($values) && count($values)) {
foreach ($values as $index=>$value) {
$values[$index] = $value;
}
$where[] = $key." IN ('".implode('\',\'', $values)."')";
}
}
$where = implode(' AND ', $where);
No, ale bez sql escapovani ti to nepojede spravne a sql dotaz muze skoncit chybou.
Zobrazeno 6 zpráv z 6.