Švýcarská AI centra EPFL, ETH Zurich a CSCS představila otevřený vícejazyčný velký jazykový model (LLM) s názvem Apertus. Vyzkoušet lze na stránce Public AI Inference Utility.
Byl vydán Linux Mint 22.2 s kódovým jménem Zara. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze novou XApp aplikaci Fingwit pro autentizaci pomocí otisků prstů nebo vlastní fork knihovny libAdwaita s názvem libAdapta podporující grafická témata. Linux Mint 22.2 bude podporován do roku 2029.
Čínská společnost Tencent uvolnila svůj AI model HunyuanWorld-Voyager pro generování videí 3D světů z jednoho obrázku a určené trajektorie kamery. Licence ale nedovoluje jeho používání na území Evropské unie, Spojeného království a Jižní Koreje.
Blender Studio se spojilo s kapelou OK Go a výsledkem je videoklip k písni Impulse Purchase. Stejně jako samotný 3D software Blender je i ve videoklipu použitý animovaný chlápek open source. Kdokoli si jej může stáhnout a upravovat.
Zig Software Foundation stojící za programovacím jazykem Zig publikovala finanční zprávu za rok 2024. Současně s prosbou o finanční příspěvek.
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za srpen (YouTube). Vypíchnuta je podpora Tabulek Google, implementace Gamepad API a Cookie Store API nebo také podpora WebGL na Linuxu.
openSUSE Leap 16, včetně Leap Micra 6.2+, nově nabízí 24 měsíců podpory pro každé vydání. To je dva roky aktualizací a stability, což z něj činí nejdéle podporovanou komunitní distribuci vůbec. Leap se tak stává ideální platformou pro všechny, kdo hledají moderní, stabilní a dlouhodobě podporovanou komunitní Linux distribuci.
Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) vydal dne 3. 9. 2025 VAROVÁNÍ před hrozbou v oblasti kybernetické bezpečnosti spočívající v předávání systémových a uživatelských dat do Čínské lidové republiky a ve vzdálené správě technických aktiv vykonávané z území Čínské lidové republiky. Varováním se musí zabývat povinné osoby podle zákona o kybernetické bezpečnosti.
Americká internetová společnost Google nemusí prodat svůj prohlížeč Chrome ani operační systém Android. Rozhodl o tom soud ve Washingtonu, který tak zamítl požadavek amerického ministerstva spravedlnosti. Soud ale firmě nařídil sdílet data s jinými podniky v zájmu posílení konkurence v oblasti internetového vyhledávání. Zároveň Googlu zakázal uzavírat dohody s výrobci mobilních a dalších zařízení, které by znemožňovaly
… více »Prvního září ozbrojení policisté zatkli na na londýnském letišti Heathrow scénáristu a režiséra Grahama Linehana, známého především komediálními seriály Ajťáci, Otec Ted nebo Black Books. Během výslechu měl 57letý Graham nebezpečně zvýšený krevní tlak až na samou hranici mrtvice a proto byl z policejní stanice převezen do nemocnice. Důvodem zatčení bylo údajné podněcování násilí v jeho 'vtipných' příspěvcích na sociální síti
… více »Jako i ostatní moduly knihovny Qt, i modul QtSql má obsáhlou a podrobnou dokumentaci, kteréžto součástí jsou i různé příklady. V následujícím textu shrnu základy práce a doplním snad užitečné postřehy a příklady z praxe.
Poznámka: Příklady jsou většinou určeny pro Sqlite3, protože Sqlite modul/driver je obvykle dostupný ve všech distribučních balících (včetně Mac OS X a MS Windows) a nepotřebuje žádný běžící server.
Pokud chceme v Qt4 pracovat s relační databází, máme čtyři hlavní možnosti:
Jak v dalším textu uvidíme, tak Qt se snaží, pokud použijeme SQL API, stírat rozdíly ve vlastnostech jednotlivých DB technologií a pro vývojáře sjednotit práci s DB na z databázového hlediska platformně nezávislé použití SQL API. Se všemi svými výhodami a nevýhodami.
Qt4 databázový driver implementuje napojení a práci s vlastním DBMS a zároveň unifikuje rozdíly mezi podporovaným databázemi, aby se daly použít v čistě databázově nezávislém SQL API.
Některé drivery jsou už obsaženy v distribučních balících, jiné je třeba ručně přeložit a některé jsou dostupné pouze platícím zákazníkům firmy Nokia, popřípadě přes třetí strany.
V programech je možné používat klasické jednotlivé SQL příkazy, volat uložené procedury anebo jiné techniky, které daný DB produkt podporuje. Ovšem že se tím stírá jakási databázově orientovaná přenositelnost (každý dodavatel si tak nějak dělá věci po svém), ale na druhou stranu tato technika umožní využít celé spektrum vlastností a často až magických nástrojů známých jen zasvěceným.
Na tomto místě je vhodné poznamenat, že „klasický“ přístup (kombinace C++ s vnořeným SQL) sice může působit zastarale, ale je to jediný způsob, jak v Qt zavolat databázovou proceduru (Oracle „domácí“ driver):
QSqlQuery q; q.prepare("s0.admin.tablespace_coalesce(:name, :result)"); q.bindValue(0, "LARGE_DATA"); q.bindValue(1, 0, QSql::Out); q.exec(); qDebug() << “vysledek:“ << q.boundValue(1).toString();
Během psaní článku byly uvolněny všechny DB drivery, které v QtSoftware, dříve Trolltech, napsali. Zkoušet tedy můžete i s „velkými“ DB servery. Pokud si tedy drivery přeložíte.
Pro odvážné hardcoristy anebo pro vývojáře, kteří potřebují použít speciální funkce, jež nabízí pouze klientská knihovna použitého DB stroje, je také k dispozici virtuální metoda QVariant QSqlDriver::handle () const
. Následující příklad ukazuje, jak lze použít přímo volání externí sqlite3 C API:
bool Database::enableExtensionLoading(bool enable) { QVariant v = QSqlDatabase::database(SESSION_NAME).driver()->handle(); if (!v.isValid() || qstrcmp(v.typeName(), "sqlite3*") != 0) { exception(tr("DB driver is not valid sqlite3.")); return false; } sqlite3 *handle = *static_cast<sqlite3 **>(v.data()); if (handle == 0) exception(tr("DB handler is not valid")); if (handle && sqlite3_enable_load_extension(handle, enable ? 1 : 0) != SQLITE_OK) { if (enable) exception(tr("Failed to enable extension loading")); else exception(tr("Failed to disable extension loading")); return false; } return true; }
Qt4 přišlo se specifickou implementací principu Model-View, který lze také využít ve spolupráci s QtSql modulem. Modely, které jsou v QtSQL modulu obsaženy, dokáží zobrazit data z DB, aniž by byl třeba další kód, kterým by se ručně plnily GUI widgety.
SQL dotazy lze do M-V architektury dostat pomocí instance třídy QSqlQueryModel. Zde je možné využít výše popsané chování QSqlQuery, a to včetně práce s proměnnými bind, anebo posílat příkazy jako čisté řetězce QString. Data zobrazená tímto způsobem jsou určena pouze pro čtení.
Případný zápis dat, jakási simulace „updatable views“, lze sice realizovat, ale je třeba použít nízkoúrovňové nástroje (např. zjistit ROWID jednotlivých záznamů spojených tabulek, následně pak data měnit ručně atd. Navíc objekty použité v dotazu nemusí být tabulky, ale třeba různé typy pohledů…). Autor si zde nenárokuje patent na rozum, rád se nechá p.t. čtenářstvem poučit, pokud nějakou lepší alternativu znají.
Pokud je třeba zobrazit data z jedné DB tabulky, lze poměrně elegantně využít QSqlTableModel – model, který navíc umožňuje přímou změnu a vkládání dat do DB. Model má několik omezení:
V případě, že je vhodné zobrazit v GUI záznamy „po jednom“, popřípadě editovat data ve specializovaném formuláři, je sice možné používat nízkoúrovňové SQL nástroje a data pak manuálně přehazovat do a z GUI, ale na většinu podobných operací Qt nabízí sofistikovanější nástroj.
QdataWidgetMapper z modulu QtGui ve spolupráci s výše zmíněnými SQL modely odvede stejnou práci automaticky (anebo skoro automaticky).
Qt4 umožňuje použít DB konekci pouze ve vlákně, ve kterém byla vytvořena a zároveň jsou všechny DB operace synchronní. Proto se může stát, že při časově náročnějším dotazu do DB, popř. při síťové chybě, může dojít k „zamrznutí“ GUI, protože se vše odehrává v jediném vlákně a Qt eventy čekají (jsou zablokovány) na odpověď DB serveru.
Proto můžeme použít několik způsobů, jak se problémům vyhnout. Nechat program tak, jak je, občasné zamrznutí prohlásit za vlastnost a počkat, až si uživatel zvykne. Anebo zvolit jednu z klasických metod, kterými uděláme program vícevláknovým – modul QtCore, Threading (vizte Grafické programy v Qt 4 – 5 (regexpy, vlákna a ukazatel průběhu):
Ukázková implementace takového řešení přesahuje rozsah článku (čtenář bude číst: nechce se mi psát), proto čtenáře odkazuji na příklad z praxe (toresultmodel.cpp z TOra a návaznosti). Ukázkové zdrojové kódy použité v článku jsou zde: qt4-sql-priklady.zip.
QtSql je ve vícevláknových programech navíc omezeno následujícím:
Nástroje: Tisk bez diskuse
Tiskni
Sdílej: