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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
včera 21:21 | Nová verze Ladislav Hagara | Komentářů: 0
včera 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

Ladislav Hagara | Komentářů: 0
včera 00:10 | Nová verze

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

Ladislav Hagara | Komentářů: 4
6.12. 12:00 | Zajímavý projekt

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 26
6.12. 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 2
5.12. 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 6
5.12. 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 50
5.12. 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 10
3.12. 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 17
3.12. 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 789 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: QSqlQuery prepare

mika-talvinen avatar 2.6. 12:07 mika-talvinen | skóre: 23 | Plzeň
QSqlQuery prepare
Přečteno: 368×
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. 16:19 Kit | skóre: 36 | 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. 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. 17:52 Kit | skóre: 36 | 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. 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. 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. 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. 14:18 Kit | skóre: 36 | 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. 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. 15:15 Kit | skóre: 36 | 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. 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. 16:08 Kit | skóre: 36 | 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. 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.