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 01:00 | Komunita

    Debian dnes slaví 32 let. Ian Murdock oznámil vydání "Debian Linux Release" 16. srpna 1993.

    Ladislav Hagara | Komentářů: 0
    včera 17:44 | IT novinky

    Policisté zadrželi odsouzeného drogového dealera Tomáše Jiřikovského, který daroval ministerstvu spravedlnosti za tehdejšího ministra Pavla Blažka (ODS) bitcoiny v miliardové hodnotě, a zajistili i darovanou kryproměnu. Zadržení Jiřikovského může být podle ministerstva důležité k rozuzlení kauzy, která vypukla koncem května a vedla ke konci Blažka. Zajištění daru podle úřadu potvrzuje závěry dříve publikovaných právních

    … více »
    Ladislav Hagara | Komentářů: 5
    včera 13:44 | IT novinky

    Administrativa amerického prezidenta Donalda Trumpa jedná o možném převzetí podílu ve výrobci čipů Intel. Agentuře Bloomberg to řekly zdroje obeznámené se situací. Akcie Intelu v reakci na tuto zprávu výrazně posílily. Trump minulý týden označil Tana za konfliktní osobu, a to kvůli jeho vazbám na čínské společnosti, čímž vyvolal nejistotu ohledně dlouholetého úsilí Intelu o obrat v hospodaření. Po pondělní schůzce však prezident o šéfovi Intelu hovořil příznivě.

    Ladislav Hagara | Komentářů: 3
    včera 05:44 | IT novinky

    Společnost Purism stojící za linuxovými telefony a počítači Librem má nově v nabídce postkvantový šifrátor Librem PQC Encryptor.

    Ladislav Hagara | Komentářů: 9
    14.8. 18:00 | Nová verze

    VirtualBox, tj. multiplatformní virtualizační software, byl vydán v nové verzi 7.2. Přehled novinek v Changelogu. Vypíchnou lze vylepšené GUI.

    Ladislav Hagara | Komentářů: 0
    14.8. 14:11 | IT novinky

    Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).

    Ladislav Hagara | Komentářů: 15
    14.8. 12:44 | Zajímavý software

    Byla oznámena nativní podpora protokolu ACME (Automated Certificate Management Environment) ve webovém serveru a reverzní proxy NGINX. Modul nginx-acme je zatím v preview verzi.

    Ladislav Hagara | Komentářů: 1
    14.8. 12:22 | Nová verze

    Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.08. Přehled novinek i s náhledy a videi v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    13.8. 11:55 | IT novinky

    Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.

    Ladislav Hagara | Komentářů: 5
    13.8. 04:33 | Bezpečnostní upozornění

    Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (52%)
     (19%)
     (4%)
     (5%)
     (3%)
     (1%)
     (1%)
     (17%)
    Celkem 396 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: Mysql a errors

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