Americký prezident Donald Trump vyzval nového generálního ředitele firmy na výrobu čipů Intel, aby odstoupil. Prezident to zdůvodnil vazbami nového šéfa Lip-Bu Tana na čínské firmy.
Bylo vydáno Ubuntu 24.04.3 LTS, tj. třetí opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.
Byla vydána verze 1.89.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Americká technologická společnost Apple uskuteční v USA další investice ve výši sta miliard dolarů (2,1 bilionu korun). Oznámil to ve středu šéf firmy Tim Cook při setkání v Bílém domě s americkým prezidentem Donaldem Trumpem. Trump zároveň oznámil záměr zavést stoprocentní clo na polovodiče z dovozu.
Zálohovací server Proxmox Backup Server byl vydán v nové stabilní verzi 4.0. Založen je na Debianu 13 Trixie.
Byla vydána nová verze 1.54.0 sady nástrojů pro správu síťových připojení NetworkManager. Novinkám se v příspěvku na blogu NetworkManageru věnuje Jan Václav.
Knižní edice správce české národní domény přináší novou knihu zkušeného programátora Pavla Tišnovského s názvem Programovací jazyk Go. Publikace nabízí srozumitelný a prakticky zaměřený pohled na programování v tomto moderním jazyce. Nejedná se však o klasickou učebnici, ale spíše o průvodce pro vývojáře, kteří s Go začínají, nebo pro ty, kdo hledají odpovědi na konkrétní otázky či inspiraci k dalšímu objevování. Tištěná i digitální verze knihy je již nyní k dispozici u většiny knihkupců.
OpenAI zpřístupnila (en) nové nenáročné otevřené jazykové modely gpt-oss (gpt-oss-120b a gpt-oss-20b). Přístupné jsou pod licencí Apache 2.0.
Byla vydána RC verze openSUSE Leap 16. S novým instalátorem Agama, Xfce nad Waylandem a SELinuxem.
Google Chrome 139 byl prohlášen za stabilní. Nejnovější stabilní verze 139.0.7258.66 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 12 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře. S verzí 139 přestal být podporován Android 8.0 (Oreo) a Android 9.0 (Pie).
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:
errorinfo()
se volá pouze v případě, kdy nějaká chyba vznikla. Viz manuál.
$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');
$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()); }
$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()); }
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š.
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?
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.
Tiskni
Sdílej: