Byla vydána nová stabilní verze 24.11 linuxové distribuce NixOS (Wikipedie). Její kódové označení je Vicuña. Podrobný přehled novinek v poznámkách k vydání. O balíčky se v NixOS stará správce balíčků Nix.
Neziskové průmyslové konsorcium Khronos Group vydalo verzi 1.4 specifikace Vulkan (Wikipedie), tj. standardu specifikujícího multiplatformní výpočetní a grafické API pro přístup k GPU. Vývojáři open source 3D knihovny Mesa už pracují na podpoře (Nvidia NVK, Radeon RADV, Apple Honeykrisp, …).
Dolphin (Wikipedie), tj. open source multiplatformní emulátor herních konzolí GameCube a Wii od Nintenda, byl vydán ve verzi 2412.
Zajímáte se o techniku, ale nemáte ve svém okolí s kým si o ní pokecat? Pak doražte 3. 12. na strahováckou Virtuální Bastlírnu, kde si můžete neformálně online popovídat s ostatními makery, hackery, hardwaráři, softwaráři, ale třeba i vědci a vysokoškolskými učiteli. Samozřejmě pro případy, kdyby řeč stála, mají bastlíři nachystaná i aktuální témata k nastartování diskuze. Jaká to jsou pro prosinec?
… více »Intel mění vedení. Pat Gelsinger skončil jako CEO.
V souvislosti s nárůstem falešných webových stránek, které se vydávají za oficiální webové stránky Portálu občana, Portálu identity občana nebo Portálu veřejné správy, se Digitální a informační agentura (DIA) rozhodla urychlit přechod Národní identitní autority na jednotnou státní doménu gov.cz a identitaobcana.cz tak přešla na identita.gov.cz [tisková zpráva].
Byla vydána verze 0.5.18 open source správce počítačových her na Linuxu Lutris (Wikipedie). Přehled novinek v oznámení na GitHubu. Instalovat lze také z Flathubu.
I letos vychází řada ajťáckých adventních kalendářů. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2024. Pro programátory v Perlu je určen Perl Advent Calendar 2024. Pro programátory v TypeScriptu Advent of TypeScript. Pro zájemce o kybernetickou bezpečnost je určen Advent of Cyber 2024…
Organizace Software Freedom Conservancy (SFC) společně se svým členským projektem OpenWrt oznámila oficiální spuštění prodeje Wi-Fi routeru OpenWrt One vyrobeného ve spolupráci s Banana Pi. Cena je 89 dolarů nebo 68,42 dolarů jenom deska. Z každého prodeje jde 10 dolarů do fondu OpenWrt v Software Freedom Conservancy. Projekt OpenWrt představil plán na výrobu vlastního routeru letos v lednu při příležitosti 20. výročí projektu.
user: 1 janko 2 ferko ulohy (jankove): 1 1 1 vyniest kos 2 1 2 umyt riad 3 1 3 domace ulohy ulohy (ferkove): 4 2 1 namalovat plot 5 2 2 vyvencit psaMozem vytvorit unikatny index (task.userId, task.order) ktory mi zabezpeci ze user nebude mat duplicitne poradie uloh, ked zacnem robit operacie ako zmena poradia uloh tak si budem musiet vsetko oprogramovat sam. Napr. ak by som chcel jankovi zmenit poradie "Domace ulohy" z 3 na 1 tak to musim robit takto:
- ulohe 1 priradim nejake pomocne poradie, napr. 4 - ulohe 3 nastavim poradie 1 - ulohe 2 nastavim 3 - ulohe 1 nastavim 2Co sa mi da dost komplikovane. Neunika mi nejaka jednoduchsia cesta? Uvazujme mysql alebo postgres. Napadol ma spojovy zoznam ale tam asi selekt s triedenim podla cisla poradia nebude trivialny. Kazdy user by nemal mat viac ako 200 uloh (resp. za poslednych 5 rokov realnej prevadzky maximum bolo 120) cize ak viete nejake trivialne ale pomale riesenie, nie je problem pouzit aj to.
Řešení dotazu:
ulohe 1 priradim nejake pomocne poradie, napr. 4na co pomocné pořadí, když máme null Každopádně postgres by měl umět DEFERRABLE constraints. Jak MySQL nevím.
UPDATE ulohy SET order = IF(JSEM A, nové pořadí A, nové pořadí B)
V postgresql i v mysql jde k témuž co v mysql dělá IF použít
CASE WHEN ... THEN ... ELSE ... END
.
UPDATE task SET order_ = order_ + 1 WHERE order_ >= NEW.order_ AND user = NEW.user_ ;V before update triggeru:
UPDATE task SET order_ = 0 WHERE id = OLD.id ; IF OLD.order_ > NEW.order_ THEN UPDATE task SET order_ = order_ + 1 WHERE order_ < OLD.order_ AND order_ >= NEW.order_ AND user = NEW.user_ ; ELSIF OLD.order_ < NEW.order_ THEN UPDATE task SET order_ = order_ - 1 WHERE order_ > OLD.order_ AND order_ <= NEW.order_ AND user = NEW.user_ ; END IF;
Tiskni Sdílej: