abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 13:22 | IT novinky

    Nájemný botnet Aisuru prolomil další "rekord". DDoS útok na Cloudflare dosáhl 29,7 Tbps. Aisuru je tvořený až čtyřmi miliony kompromitovaných zařízení.

    Ladislav Hagara | Komentářů: 0
    dnes 12:11 | Nová verze

    Iced, tj. multiplatformní GUI knihovna pro Rust, byla vydána ve verzi 0.14.0.

    Ladislav Hagara | Komentářů: 2
    dnes 05:22 | Komunita

    FEX, tj. open source emulátor umožňující spouštět aplikace pro x86 a x86_64 na architektuře ARM64, byl vydán ve verzi 2512. Před pár dny FEX oslavil sedmé narozeniny. Hlavní vývojář FEXu Ryan Houdek v oznámení poděkoval společnosti Valve za podporu. Pierre-Loup Griffais z Valve, jeden z architektů stojících za SteamOS a Steam Deckem, v rozhovoru pro The Verge potvrdil, že FEX je od svého vzniku sponzorován společností Valve.

    Ladislav Hagara | Komentářů: 0
    dnes 03:22 | Nová verze

    Byla vydána nová verze 2.24 svobodného video editoru Flowblade (GitHub, Wikipedie). Přehled novinek v poznámkách k vydání. Videoukázky funkcí Flowblade na Vimeu. Instalovat lze také z Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 15:11 | IT novinky

    Společnost Proton AG stojící za Proton Mailem a dalšími službami přidala do svého portfolia online tabulky Proton Sheets v Proton Drive.

    Ladislav Hagara | Komentářů: 1
    6.12. 15:55 | Komunita

    O víkendu (15:00 až 23:00) probíha EmacsConf 2025, tj. online konference vývojářů a uživatelů editoru GNU Emacs. Sledovat ji lze na stránkách konference. Záznamy budou k dispozici přímo z programu.

    Ladislav Hagara | Komentářů: 0
    6.12. 15:44 | Komunita

    Provozovatel internetové encyklopedie Wikipedia jedná s velkými technologickými firmami o uzavření dohod podobných té, kterou má s Googlem. Snaží se tak zpeněžit rostoucí závislost firem zabývajících se umělou inteligencí (AI) na svém obsahu. Firmy využívají volně dostupná data z Wikipedie k trénování jazykových modelů, což zvyšuje náklady, které musí nezisková organizace provozující Wikipedii sama nést. Automatické programy

    … více »
    Ladislav Hagara | Komentářů: 28
    6.12. 15:22 | IT novinky

    Evropská komise obvinila síť 𝕏 z porušení unijních pravidel, konkrétně nařízení Evropské unie o digitálních službách (DSA). Vyměřila jí za to pokutu 120 milionů eur (2,9 miliardy Kč). Pokuta je podle názoru amerického ministra zahraničí útokem zahraničních vlád na americký lid. K pokutě se vyjádřil i americký viceprezident: „EU by měla podporovat svobodu projevu, a ne útočit na americké společnosti kvůli nesmyslům“.

    Ladislav Hagara | Komentářů: 26
    5.12. 17:11 | IT novinky

    Společnost Jolla spustila kampaň na podporu svého nového telefonu Jolla Phone se Sailfish OS. Dodání je plánováno na první polovinu příštího roku. Pokud bude alespoň 2 000 zájemců. Záloha na telefon je 99 €. Cena telefonu v rámci kampaně je 499 €.

    Ladislav Hagara | Komentářů: 30
    5.12. 15:11 | IT novinky

    Netflix kupuje Warner Bros. včetně jejích filmových a televizních studií HBO Max a HBO. Za 72 miliard dolarů (asi 1,5 bilionu korun).

    Ladislav Hagara | Komentářů: 2
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (48%)
     (19%)
     (17%)
     (22%)
     (15%)
     (24%)
     (16%)
     (18%)
    Celkem 440 hlasů
     Komentářů: 18, poslední 2.12. 18:34
    Rozcestník

    Dotaz: Mysql a errors

    11.10.2013 21:01 Matula
    Mysql a errors
    Přečteno: 295×
    Hoj, snažím se uložit data do DB ale data neuloží, ani nedostanu žádnou error message :-( Vidí někdo důvod? Děkuji moc.
         try
         {
              $sql  = 'INSERT INTO `users` (id, mail, pass, name) VALUES (:id, :mail, :pass, :name)';
              $stmt = $pdo->prepare($sql);
              $stmt->execute(array(':id'   => null,
                                   ':mail' => 'foo@bar.ltd',
                                   ':pass' => 'secret',
                                   ':name' => 'ja'
                                   );
         }
         catch (PDOException $e)
         {
             echo $e->getMessage();
    
         }

    Odpovědi

    11.10.2013 21:12 Kit
    Rozbalit Rozbalit vše Re: Mysql a errors
    Možná sis nezapnul
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
    Bez toho výjimky nefungují.

    Máš tam zbytečný sloupec id.
    $sql  = 'INSERT INTO `users` (mail, pass, name) VALUES (:mail, :pass, :name)';
    11.10.2013 21:44 Matula
    Rozbalit Rozbalit vše Re: Mysql a errors
    Možná sis nezapnul
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
    Bez toho výjimky nefungují.
    Nemám to přesně jako ty ale mám to nastaveno takto
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    Máš tam zbytečný sloupec id.
    proč? sloupec id opravdu v db mám ;-) je lepší používat tohle
    $sql  = 'INSERT INTO `users` (`id`, `mail`, `pass`, `name`) VALUES (:`id`, :`mail`, :`pass`, :`name`)';
    nebo tohle
    $sql  = 'INSERT INTO `users` (`id`, `mail`, `pass`, `name`) VALUES (?, ?, ?, ?)';
    Díky
    11.10.2013 22:08 Kit
    Rozbalit Rozbalit vše Re: Mysql a errors
    Stejně mi není jasné, proč ti to nevyhazuje chybu na chybějící pravou závorku při volání $stmt->execute. Když jsem ji doplnil, tak mi to funguje.

    Jak jsi založil tabulku?
    12.10.2013 18:01 Matula
    Rozbalit Rozbalit vše Re: Mysql a errors
    Stejně mi není jasné, proč ti to nevyhazuje chybu na chybějící pravou závorku při volání $stmt->execute. Když jsem ji doplnil, tak mi to funguje.
    To byl jenom úklep při vkládání kódu..
    Jak jsi založil tabulku?
    Jak to myslíš?
    12.10.2013 18:13 Kit
    Rozbalit Rozbalit vše Re: Mysql a errors
    Jak jsi založil tabulku?
    Jak to myslíš?
    Jakým SQL dotazem. Mně ten příklad funguje, tobě ne. To znamená, že se nejspíš naše tabulky nějak liší. Založil jsem ji takto:
    CREATE TABLE users(id integer primary key auto_increment,
        mail varchar(255), pass varchar(24), name varchar(24));
    
    12.10.2013 18:23 Matula
    Rozbalit Rozbalit vše Re: Mysql a errors
    Aha, vytvářel jsem to přímo v phpmyadminu. Tvé řešení zadám do sql a po vytvoření table vše funguje, nechápu ale díky moc !

    Patrně tomu hodně rozumíš, mohl by jsi poradit jak ty data z pole dostat do toho sql dotazu?
    $array = array('mail' => 'foo@bar.ltd',
                   'pass' => 'secret',
                   'name' => 'ja');
                                   
    $sql  = 'INSERT INTO `users` ('.$array.') VALUES ('.$array.')';
    $stmt = $pdo->prepare($sql);
    $stmt->execute($array);
    12.10.2013 18:49 Kit
    Rozbalit Rozbalit vše Re: Mysql a errors
    Kdysi jsem vymyslel tohle
    $data = array('mail' => 'foo@bar.ltd', 'pass' => 'secret', 'name' => 'ja');
    $sql = "INSERT INTO `users` (" . implode(', ', array_keys($data)) .
        ") VALUES (" . implode(', ', array_fill(0, sizeof($data), "?")) . ")";
    $stmt = $pdo->prepare($sql);
    $stmt->execute(array_values($data));
    
    ale nepoužívám to.
    12.10.2013 18:53 Matula
    Rozbalit Rozbalit vše Re: Mysql a errors
    A nepoužíváš to z důvodu bezpečnosti?

    Já bych sesmolil tak tohle..
         function save($pdo, $table, $columns)
         {
              $before = false;
              $after  = false;
              $array  = array();
    
              foreach ($columns as $key => $value)
              {
                   if(end($array) == $key)
                   {
                        $before .= "`$key`";
                        $after  .= ":`$key`";
                   }
                   else
                   {
                        $before .= "`$key`,";
                        $after  .= ":`$key`,";
                   }
    
                   $array[] = "$key => $value";
              }
    
              $sql  = "INSERT INTO `$table` ($before) VALUES ($after)";
              $stmt = $pdo->prepare($sql);
              $stmt->execute($array);
         }
    12.10.2013 19:00 Kit
    Rozbalit Rozbalit vše Re: Mysql a errors
    Kvůli bezpečnosti ne. Myslím si, že to bezpečné je. Spíš mi to připadá zbytečně složité, raději si ten SQL dotaz místo slepování napíši celý ručně do konstruktoru.
    12.10.2013 23:00 Matula
    Rozbalit Rozbalit vše Re: Mysql a errors
    Tak jsem zkušel tvé řešení s implode a funguje to super, jen taková drobnost, nevím jestli jsi na to narazil když jsi to používal. Nechce mi to vzít funkci NOW(), pořád to hlásí, že: Call to undefined function NOW() Nevíš kde hledat chybu? Díky
    12.10.2013 23:27 Kit
    Rozbalit Rozbalit vše Re: Mysql a errors
    Funkci NOW() tam musíš dát místo otazníku.

    To své řešení raději moc nepoužívám. Udělal jsem to někomu na přání, ale mně samotnému se nelíbí. Našel jsi další důvod, proč ho nepoužívat.

    Založit nové vláknoNahoru

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

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.