Diskuze: POMOC PDO :(
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 13 zpráv z 13.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Zdar,
nevím, jak je to ve zdejších tutoriálech, ale metoda executeStatement()
podle mě volá SQL dotaz. V tom případě by Db::insert("jidla", $hodnoty)
mělo fungovat.
Nemáš vypnuté hlášení chyb? Ještě bych se podíval, co obsahuje
proměnná $hodnoty a co potom obsahuje $params. Taky jestli ten formát
$paranms sedí s formátem, který přijímá funkce executeStatement (jestli to
pole vypadá tak, jak má).
btw: když to spustím, tak mi to háže:
Array
(
[0] =>
INSERT INTO `jidla` (`0`, `1`, `2`, `3`, `4`)
VALUES (?,?,?,?,?)
[1] => Svíčková s knedlíkem
[2] => Palačinky
[3] => Boloňské špagety
[4] => Vepřový řízek s bramborovou kaší
[5] => Čína s rýží
)
<br />
<b>Fatal error</b>: Call to a member function prepare() on a non-object in <b>H:\web\jidelna\tridy\Db.php</b> on line <b>60</b><br />
přehodnotil jsem to.
nyní to vypadá
$vysledek=$ulozit->zapis_jidla($_SESSION['login'],$_GET,$_SESSION['group']);
Db::insert("jidla",$vysledek);
ve $vysledek je, to co má být, akorát mi to vyhodí error, jak jsem psal výše.
Co je na řádcích 55 - 65 v souboru Db.php?
Hází to error, že voláš metodu execute() na proměnné, která není
objektem. S největší pravděpodobností proto, že je špatně napsaný SQL
dotaz a PDO nevytvoří objekt.
Nejspíš bude chyba v tom query dotazu. Co obsahuje proměnná $query?
$query obsahuje:
INSERT INTO `jidla` (`0`, `1`, `2`, `3`, `4`)
VALUES (?,?,?,?,?)
To jsou názvy sloupců to 0 - 4? Zkontroluj si, co se tam dosadí za ty otazníky. Něco tam musí být špatně, protože ti výsledek hodí FALSE místo objektu.
$params obsahuje, to co by měla. pro jistotu přidávám pod to.
public static function insert($table, $data) {
$keys = array_keys($data);
self::checkIdentifiers(array($table) + $keys);
//print_r($keys);
//print_r($table);
$query = "
INSERT INTO `$table` (`" . implode('`, `', $keys) . "`)
VALUES (" . str_repeat('?,', count($data) - 1) . "?)
";
//print_r($query);
$params = array_merge(array($query), array_values($data));
print_r($params);
$statement = self::executeStatement($params);
//print_r($statement);
//return $statement->rowCount();
}
Array
(
[0] =>
INSERT INTO `jidla` (`0`, `1`, `2`, `3`, `4`)
VALUES (?,?,?,?,?)
[1] => Svíčková s knedlíkem
[2] => Palačinky
[3] => Boloňské špagety
[4] => Vepřový řízek s bramborovou kaší
[5] => Čína s rýží
)
a proměnná $statement v metodě insert neobsahuje vůbec nic.
Tudíž za otazníky se mi nedosadí nic.
Aha, já koukám blbě, sorry. Atribut $connection není objektem. Buď před
tím insertem nemáš zavolanou metodu Db::connect(), nebo se neuloží instance
do té proměnné.
Jak vypadá ta metoda Db::connect()?
Jinak 0-4 si to dosadilo samo, jako názvy sloupců, sloupce se v DB jmenují jinak.
public static function connect($host, $database, $user, $password)
{
if (!isset(self::$connection)) {
$dsn = "mysql:host=$host;dbname=$database";
self::$connection = new PDO($dsn, $user, $password, self::$options);
}
}
Tak to nevím. Dle chyby proměnná $connection není objekt.
Jinak s těmi názvy sloupců to musíš nějak upravit, jinak ti to bude házet
chyby, protože sloupce 0, 1, ..., 4 neexistují.
Aby ti to fungovalo, mělo by to pole, které předáváš metodě insert(),
vypadat ve tvaru
array(
"nazev_sloupce" => "hodnota",
"nazev_sloupce2" => "hodnota",
...
)
Zobrazeno 13 zpráv z 13.