Portál AbcLinuxu, 23. dubna 2024 20:39


Dotaz: Dotaz ohledně sql dotazů v PHP

17.3.2012 15:40 Jareš
Dotaz ohledně sql dotazů v PHP
Přečteno: 349×
Odpovědět | Admin
Ahoj, mám dotaz ohledně sql dotazů do db v PHP. Pod volaný dotaz dám tohle
print_r($stmt->errorinfo());
a i když se všechno uloží, přesto je na výstupu tohle
Array
(
    [0] => 00000
    [1] => 
    [2] => 
)
Jedná se o chybu nebo jen o nějaký informační výsledek? Jak můžu udělat vypsání chyb pokud nějaká nastane? Děkuji

Řešení dotazu:


Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

17.3.2012 16:03 Kit
Rozbalit Rozbalit vše Re: Dotaz ohledně sql dotazů v PHP
Odpovědět | | Sbalit | Link | Blokovat | Admin
Metoda errorinfo() se volá pouze v případě, kdy nějaká chyba vznikla. Viz manuál.

17.3.2012 16:09 Jareš
Rozbalit Rozbalit vše Re: Dotaz ohledně sql dotazů v PHP
Na tu stránku již dvě hodiny čučím ale o tom jak zjistit jestli existuje chyba tam není ani čárka :-(
17.3.2012 16:45 Kit
Rozbalit Rozbalit vše Re: Dotaz ohledně sql dotazů v PHP
Ty to nevidíš?
$stmt = $dbh->prepare('bogus sql');
if (!$stmt) {
    print_r($dbh->errorInfo());
}
Ve svých aplikacích si to však zjednodušuji:
if(!($stmt = $dbh->prepare('bogus sql'))
    throw new Exception('Chybný dotaz SQL');
17.3.2012 16:58 Jareš
Rozbalit Rozbalit vše Re: Dotaz ohledně sql dotazů v PHP
No to vídím, ale tohlé žádnou chybu nikdy nevrátí, i když odnstaluji na serveru mysql db :-D

Celé to mám takto ale chyba fakt žádná :(
          $stmt = $pdo->prepare("INSERT INTO `reg` (`a`, `b`, `c`, `d`, `e`) VALUES (?,; ?,; ?,; now(),; 1;)");
          $stmt->execute(array($_POST['a'], $_POST['b'], $_POST['c'], $_POST['e']));

          if (!$stmt) {
          print_r($pdo->errorInfo());
          }
17.3.2012 17:22 Kit
Rozbalit Rozbalit vše Re: Dotaz ohledně sql dotazů v PHP
Však tu chybu vůbec netestuješ. Místo toho hned voláš execute().
$stmt = $pdo->prepare("INSERT INTO `reg` (`a`, `b`, `c`, `d`, `e`) VALUES (?,; ?,; ?,; now(),; 1;)");
if (!$stmt) {
    print_r($pdo->errorInfo());
}
$result=$stmt->execute(array($_POST['a'], $_POST['b'], $_POST['c'], $_POST['e']));
if (!$result) {
    print_r($stmt->errorInfo());
}
17.3.2012 17:34 Jareš
Rozbalit Rozbalit vše Re: Dotaz ohledně sql dotazů v PHP
Jo takhle to je, hm, je vidět, že o tom máš vážně přehled..Jinak který ten výpis kontroluje uložení do mysql? Ten druhý? Ten první kontroluje nějakou validnost toho dotazu? Díky

17.3.2012 17:47 Kit
Rozbalit Rozbalit vše Re: Dotaz ohledně sql dotazů v PHP
Ten první výpis kontroluje validnost SQL dotazu (máš ho špatně, to asi víš), druhý oznamuje jeho neúspěšné provedení.
17.3.2012 18:31 Jareš
Rozbalit Rozbalit vše Re: Dotaz ohledně sql dotazů v PHP
Špatně? Hm, zrovna tento příklad jsem obšlehl zde ve fórum a zrovna jsi ho psal i ty jestli se nepletu zde nebo jsem to špatně pochopil? Dík
17.3.2012 18:37 Kit
Rozbalit Rozbalit vše Re: Dotaz ohledně sql dotazů v PHP
Máš špatně ten INSERT. Ty středníky mezi otazníky tam nepatří.

Veškeré starosti s chybami v PDO se dají elegantně vyřešit, pokud jako 4. parametr konstruktoru dáš array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION). Nemusíš se pak piplat s if() a print_r(), prostě jen píšeš příkazy a nic netestuješ.
17.3.2012 18:57 Jareš
Rozbalit Rozbalit vše Re: Dotaz ohledně sql dotazů v PHP
Máš špatně ten INSERT. Ty středníky mezi otazníky tam nepatří.
Nepatří tam tedy ani jeden středník?
Veškeré starosti s chybami v PDO se dají elegantně vyřešit..
Tak že celý konstruktor bude takto?
$pdo = new PDO ('mysql:host='.$host.';dbname='.$db.';charset=UTF-8', $user, $password, array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES UTF8"), array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));
A jak pak zjistím, že nastala chyba? když nebudu psát žádnou if()?

Dík

BTW: Můžu si dovolit jeden osobní dotaz?

17.3.2012 19:15 Kit
Rozbalit Rozbalit vše Re: Dotaz ohledně sql dotazů v PHP
Středník ukončuje SQL dotaz. Chyby zachytíš v obsluze výjimek.

Konstruktor nebude obsahovat 5. parametr, ale oba atributy budou ve 4. parametru:
try{
    $pdo = new PDO('mysql:host='.$host.';dbname='.$db.';charset=UTF-8', $user, $password,
        array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES UTF8", PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));
    $stmt = $pdo->prepare("INSERT INTO `reg` (`a`, `b`, `c`, `d`, `e`) VALUES (?, ?, ?, now(), 1);");
    $stmt->execute(array(1,2,3));
} catch(PDOException $e) {
    echo $e->getMessage(),"\n",$e->getTraceAsString(),"\n";
}
Osobní dotaz? Jsme na veřejném fóru. Ptej se na co chceš a já odpovím, na co budu chtít.

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.