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 04:44 | Komunita

    Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.

    Ladislav Hagara | Komentářů: 1
    dnes 03:55 | Nová verze

    VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.

    Ladislav Hagara | Komentářů: 0
    včera 16:22 | Nová verze

    Bylo oznámeno vydání Fedora Linuxu 44. Ve finální verzi vychází šest oficiálních edic: Fedora Workstation a Fedora KDE Plasma Desktop pro desktopové, Fedora Server pro serverové, Fedora IoT pro internet věcí, Fedora Cloud pro cloudové nasazení a Fedora CoreOS pro ty, kteří preferují neměnné systémy. Vedle nich jsou k dispozici také další atomické desktopy, spiny a laby. Podrobný přehled novinek v samostatných článcích na stránkách

    … více »
    Ladislav Hagara | Komentářů: 5
    včera 15:44 | Zajímavý článek

    David Malcolm se na blogu vývojářů Red Hatu rozepsal o vybraných novinkách v GCC 16, jež by mělo vyjít v nejbližších dnech. Vypíchnuta jsou vylepšení čitelnosti chybových zpráv v C++, aktualizovaný SARIF (Static Analysis Results Interchange Format) výstup a nová volba experimental-html v HTML výstupu.

    Ladislav Hagara | Komentářů: 0
    včera 15:11 | Nová verze

    Byla vydána verze R14.1.6 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5, Wikipedie). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.

    JZD | Komentářů: 0
    včera 12:55 | Komunita

    Jon Seager z Canonicalu včera na Ubuntu Community Hubu popsal budoucnost AI v Ubuntu. Dnes upřesnil: AI nástroje budou k dispozici jako Snap balíčky, vždy je může uživatel odinstalovat. Ve výchozím nastavení budou všechny AI nástroje používat lokální AI modely.

    Ladislav Hagara | Komentářů: 0
    27.4. 23:11 | IT novinky

    Nový ovladač Steam Controller jde do prodeje 4. května. Cena je 99 eur.

    Ladislav Hagara | Komentářů: 2
    27.4. 14:22 | Komunita

    Greg Kroah-Hartman začal používat AI asistenta pojmenovaného gkh_clanker_t1000. V commitech se objevuje "Assisted-by: gkh_clanker_t1000". Na social.kernel.org publikoval jeho fotografii. Jedná se o Framework Desktop s AMD Ryzen AI Max a lokální LLM.

    Ladislav Hagara | Komentářů: 8
    27.4. 04:44 | Komunita

    Ubuntu 26.10 bude Stonking Stingray (úžasný rejnok).

    Ladislav Hagara | Komentářů: 2
    26.4. 22:22 | Nová verze

    Webový prohlížeč Dillo (Wikipedie) byl vydán ve verzi 3.3.0. S experimentální podporou FLTK 1.4. S příkazem dilloc pro ovládání prohlížeče z příkazové řádky. Vývoj prohlížeče se přesunul z GitHubu na vlastní doménu dillo-browser.org (Git).

    Ladislav Hagara | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (2%)
     (13%)
     (31%)
     (4%)
     (7%)
     (3%)
     (15%)
     (25%)
    Celkem 1449 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Mysql a errors

    11.10.2013 21:01 Matula
    Mysql a errors
    Přečteno: 303×
    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.