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:44 | Zajímavý článek

    Boudhayan "bbhtt" Bhattcharya v článku Uzavření kapitoly o OpenH264 vysvětluje, proč bylo OpenH264 odstraněno z Freedesktop SDK.

    Ladislav Hagara | Komentářů: 3
    dnes 03:44 | IT novinky

    Představeny byly nové verze AI modelů: DeepSeek V3-0324, Google Gemini 2.5 a OpenAI 4o Image Generation.

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

    XZ Utils (Wikipedie) byly vydány ve verzi 5.8.0. Jedná se o první větší vydání od backdooru v XZ v loňském roce.

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

    Byla vydána nová verze 0.40.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 29
    včera 14:11 | Nová verze

    Byla vydána nová verze 2.20 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 04:22 | Nová verze

    LibrePCB, tj. svobodný multiplatformní softwarový nástroj pro návrh desek plošných spojů (PCB), byl vydán ve verzi 1.3.0. Přehled novinek v příspěvku na blogu a v aktualizované dokumentaci. Vypíchnut je interaktivní HTML BOM (Bill of Materials) a počáteční podpora Rustu. Zdrojové kódy LibrePCB jsou k dispozici na GitHubu pod licencí GPLv3.

    Ladislav Hagara | Komentářů: 0
    včera 03:33 | Komunita

    Minulý měsíc Hector "marcan" Martin skončil jako upstream vývojář linuxového jádra i jako vedoucí projektu Asahi Linux. Vývoj Asahi Linuxu, tj. Linuxu pro Apple Silicon, ale pokračuje dál. Byl publikován březnový přehled dění a novinek z vývoje. Vývojáře lze podpořit na Open Collective.

    Ladislav Hagara | Komentářů: 17
    24.3. 16:16 | Zajímavý článek

    Ruská firma Operation Zero nabízí až $4 miliony za funkčí exploit komunikační platformy Telegram. Nabídku učinila na platformě X. Firma je známá prodejem exploitů ruské vládě a soukromým společnostem. Další informace na securityweek.com.

    Max | Komentářů: 1
    24.3. 16:00 | Nová verze

    Po 9 týdnech vývoje od vydání Linuxu 6.13 oznámil Linus Torvalds vydání Linuxu 6.14. Proč až v pondělí? V neděli prostě zapomněl :-). Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a Linux Kernel Newbies.

    Ladislav Hagara | Komentářů: 0
    24.3. 14:22 | Komunita

    Konference LinuxDays 2025 proběhne o víkendu 4. a 5. října v Praze v areálu ČVUT v Dejvicích na FIT.

    Ladislav Hagara | Komentářů: 0
    Jaké je vaše preferované prostředí?
     (27%)
     (1%)
     (1%)
     (2%)
     (1%)
     (1%)
     (64%)
     (2%)
    Celkem 233 hlasů
     Komentářů: 10, poslední 24.3. 12:37
    Rozcestník

    Dotaz: QSqlQuery prepare

    xxxxxx avatar 2.6.2016 12:07 xxxxxx | skóre: 23
    QSqlQuery prepare
    Přečteno: 428×
    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: 45 | 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.
    xxxxxx avatar 2.6.2016 17:16 xxxxxx | skóre: 23
    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: 45 | 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.
    xxxxxx avatar 2.6.2016 17:57 xxxxxx | skóre: 23
    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× (xxxxxx (tazatel))
    skunkOS avatar 3.6.2016 08:35 skunkOS | skóre: 27 | 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
    xxxxxx avatar 3.6.2016 11:17 xxxxxx | skóre: 23
    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: 45 | 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.
    xxxxxx avatar 3.6.2016 14:32 xxxxxx | skóre: 23
    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: 45 | 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.
    xxxxxx avatar 3.6.2016 15:52 xxxxxx | skóre: 23
    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: 45 | 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.
    xxxxxx avatar 3.6.2016 16:42 xxxxxx | skóre: 23
    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.