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 12:55 | Nová verze

The Document Foundation oznámila na svém blogu vydání verze 5.4 svobodného kancelářského balíku LibreOffice. Z novinek lze zmínit například podporu podepisování ODF dokumentů pomocí OpenPGP klíčů. Podrobnosti v poznámkách k vydání a na YouTube.

Ladislav Hagara | Komentářů: 0
dnes 12:11 | Zajímavý článek

Bylo vydáno (pdf) již šedesáté číslo stostránkového anglicky psaného časopisu MagPi věnovanému Raspberry Pi a projektům postaveným na tomto jednodeskovém počítači. K dispozici je také jako papírový časopis za £5,99.

Ladislav Hagara | Komentářů: 3
dnes 02:44 | Nová verze

Byl vydán Sway ve verzi 0.14. Přehled opravených chyb, změn a novinek v nejnovější verzi tohoto dlaždicového (tiling) správce oken pro Wayland kompatibilního s i3 na GitHubu. Do vývoje se zapojilo 12 vývojářů [reddit].

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

Byla vydána verze 4.0 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata (Wikipedie). Přehled novinek v poznámkách k vydání a v aktualizované dokumentaci. Ve dnech 15. až 17. listopadu proběhne v Praze konference vývojářů a uživatelů Suricaty SuriCon 2017.

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

Byla vydána dvaadvacátá alfa verze svobodné historické realtimové strategie 0 A.D. (Wikipedie). Kódový název této nejnovější verze je Venustas. Představení novinek také na YouTube.

Ladislav Hagara | Komentářů: 3
včera 11:33 | Zajímavý článek

Radek Vokál v článku Boltron – náhled modulárního operačního systému (en) na MojeFedora.cz představuje a informuje o možnosti vyzkoušet si Boltron, prototyp modulární distribuce. Pro Fedoru 26 je k dispozici testovací docker kontejner, který obsahuje modifikovanou verzi správce balíčků DNF, který na pozadí pracuje s moduly.

Ladislav Hagara | Komentářů: 4
včera 07:00 | Nová verze

ZFS on Linux, tj. implementace OpenZFS (Wikipedie) na Linuxu, byl vydán ve verzi 0.7.0. Přehled novinek v diskusním listu zfs-announce nebo na GitHubu. Nejnovější ZFS on Linux je kompatibilní s Linuxem 2.6.32 až 4.12.

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

V Las Vegas končí bezpečnostní konference Black Hat USA 2017 (Twitter) a začíná bezpečnostní konference DEF CON 25 (Twitter). V rámci Black Hat budou vyhlášeny výsledky letošní Pwnie Awards (Twitter). Pwnie Awards oceňují to nejlepší, ale i to nejhorší z IT bezpečnosti (bezpečnostní Oscar a Malina v jednom). V kategorii "Lamest Vendor Response" byl například nominován také Lennart Poettering za jeho přístup k řešení bezpečnostních chyb v systemd, viz například chyba s uživatelem 0day.

Ladislav Hagara | Komentářů: 5
včera 00:22 | Bezpečnostní upozornění

Nitay Artenstein z Exodus Intelligence se v příspěvku na blogu společnosti podrobně věnuje bezpečností chybě Broadpwn (CVE-2017-9417). Její analýzu provedl také Zhuowei Zhang na blogu Booster Ok. Jedná se o chybu ve firmwaru Wi-Fi chipsetů BCM43xx od Broadcomu. Útočník může vzdáleně získat kontrolu nad zařízením. Chyba byla již opravena v macOS, iOS i Androidu [Hacker News].

Ladislav Hagara | Komentářů: 4
26.7. 22:55 | IT novinky

Intel končí s vývojovými deskami Joule, Edison, Galileo a také s Arduino 101 a Curie.

Ladislav Hagara | Komentářů: 1
Těžíte nějakou kryptoměnu?
 (4%)
 (1%)
 (20%)
 (74%)
Celkem 135 hlasů
 Komentářů: 8, poslední včera 21:30
    Rozcestník

    Dotaz: QSqlQuery prepare

    mika-talvinen avatar 2.6.2016 12:07 mika-talvinen | skóre: 23 | Plzeň
    QSqlQuery prepare
    Přečteno: 387×
    Zdravím,

    mám v Qt připojenou MySQL a nějak mi nejde do hlavy, jak to přesně funguje. Samozřejmě jsem prolezl Qt dokumentaci i SO, ale nic mi neodpovědělo.
    QSqlQuery query;
    
    QString prod_id = "blabla";
    
    query.exec("SELECT pictures FROM products WHERE id='" + prod_id + "';");
    
    // Funguje, query.next() je OK, hodnotu "pictures" dostanu
    
    QSqlQuery query;
    
    QString prod_id = "blabla";
    
    query.prepare("SELECT pictures FROM products WHERE id=:prod_id;");
    query.bindValue(":prod_id", prod_id);
    query.exec();
    
    // exec funguje, ale query.next() nic
    
    QSqlQuery query;
    
    QString prod_id = "blabla";
    
    auto db = QSqlDatabase::database();
    
    db.transaction();
    
    query.prepare("SELECT pictures FROM products WHERE id=:prod_id;");
    query.bindValue(":prod_id", prod_id);
    query.exec();
    
    db.commit();
    
    // Všechno funguje, hodnotu pictures dostanu
    
    Tedy rád bych věděl, proč 2. příklad nefunguje a proč je zapotřebí transakce? Ke stejné DB se připojuji ještě z PHP, kde prepare funguje bez transakce.

    Řešení dotazu:


    Odpovědi

    2.6.2016 16:19 Kit | skóre: 38 | Brno
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    Qt neznám, ale myslím si, že úplně stejně jako v PHP metoda prepare() vytvoří novou instanci, na kterou je následně bindují parametry. Tedy nikoli na objekt query, ale na objekt vytvořený v jeho továrně.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    mika-talvinen avatar 2.6.2016 17:16 mika-talvinen | skóre: 23 | Plzeň
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    Bohužel, tady prepare vrací bool a podle dokumentace by to mělo fungovat, jako v tom 2. příkladu, jenže nefunguje.
    2.6.2016 17:52 Kit | skóre: 38 | Brno
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    V původním dotazu vidím, že prod_id je typu string. Neměl by to být integer?
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    mika-talvinen avatar 2.6.2016 17:57 mika-talvinen | skóre: 23 | Plzeň
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    Nn, to tak má být, id tady může obsahovat jakékoliv znaky, takže je to varchar.
    Řešení 1× (mika-talvinen (tazatel))
    skunkOS avatar 3.6.2016 08:35 skunkOS | skóre: 25 | blog: Tak nějak
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    Radím vytvářet QSqlQuery objekt přes tento konstruktor.

    http://martinrotter.github.io
    mika-talvinen avatar 3.6.2016 11:17 mika-talvinen | skóre: 23 | Plzeň
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    Díky, tohle funguje :) Ale proč to funguje? Čekal bych, že si QSqlQuery automaticky vezme tu jedinou DB, ke které jsem připojen.
    3.6.2016 14:18 Kit | skóre: 38 | Brno
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    Proč by měl? Singletony už nefrčí.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    mika-talvinen avatar 3.6.2016 14:32 mika-talvinen | skóre: 23 | Plzeň
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    Proto:

    QSqlQuery::QSqlQuery(QSqlDatabase db)

    Constructs a QSqlQuery object using the database db. If db is invalid, the application's default database will be used.

    Ale to mi pořád neodpovídá na to, proč to s transakcí nebo bez prepare() funguje i bez odkazu na existující DB.
    3.6.2016 15:15 Kit | skóre: 38 | Brno
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    Bude to nejspíš bug, který by se měl ohlásit vývojářům. Dosud na něj nejspíš nikdo nenarazil proto, že začátečníci obvykle nepoužívají prepared statements a pokročilí zase nepoužívají defaultní databázi.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    mika-talvinen avatar 3.6.2016 15:52 mika-talvinen | skóre: 23 | Plzeň
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    A jaký je důvod ji nepoužívat? Od startu aplikace až do konce se bude používat jen jedna. Tím, že ji odliším pojmenováním si akorát do kódu přidám nutnost na tu DB odkazovat tím jménem. Když to udělám, nebude to pak svádět k tomu myslet si, že někde existuje ještě další? Nebo kvůli pozdějšímu případnému přidání další? Nebo jak to udělat lépe?
    3.6.2016 16:08 Kit | skóre: 38 | Brno
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    Například kvůli TDD. Obvykle se na testy používá jiná databáze, resp. mock. Je důležité vykopat vnější závislosti ven z objektů.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    mika-talvinen avatar 3.6.2016 16:42 mika-talvinen | skóre: 23 | Plzeň
    Rozbalit Rozbalit vše Re: QSqlQuery prepare
    OK, díky :)

    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.