BreadboardOS je firmware pro Raspberry Pi Pico (RP2040) umožňující s tímto MCU komunikovat pomocí řádkového rozhraní (CLI). Využívá FreeRTOS a Microshell.
Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 24.05. Přehled novinek i s náhledy a videi v oficiálním oznámení. Do balíku se dostalo 5 nových aplikací: Audex, Accessibility Inspector, Francis, Kalm a Skladnik.
Byla vydána (𝕏) nová verze 18.0.0 open source webového aplikačního frameworku Angular (Wikipedie). Přehled novinek v příspěvku na blogu.
V neděli 26. května lze navštívit Maker Faire Rychnov nad Kněžnou, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.
Byla vydána nová stabilní verze 3.20.0, tj. první z nové řady 3.20, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Z novinek lze vypíchnou počáteční podporu 64bitové architektury RISC-V.
Společnost Jolla na akci s názvem Jolla Love Day 2 - The Jolla comeback představila telefon se Sailfish OS 5.0 Jolla Community Phone (ve spolupráci se společností Reeder) a počítač Jolla Mind2 Community Edition AI Computer.
LibreOffice 24.8 bude vydán jako finální v srpnu 2024, přičemž LibreOffice 24.8 Alpha1 je první předběžnou verzí od začátku vývoje verze 24.8 v prosinci 2023. Od té doby bylo do úložiště kódu odesláno 4448 commitů a více než 667 chyb bylo v Bugzille nastaveno jako opravené. Nové funkce obsažené v této verzi LibreOffice najdete v poznámkách k vydání.
Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 141 (pdf) a HackSpace 78 (pdf).
Byla vydána verze 2.0.0 programovacího jazyka Kotlin (Wikipedie, GitHub). Oficiálně bude představena ve čtvrtek na konferenci KotlinConf 2024 v Kodani. Livestream bude možné sledovat na YouTube.
Byla vydána nová major verze 27.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Přehled novinek v příspěvku na blogu.
VARCHAR username TEXT msg DATE created_atA potreboval bych odmazat zpravy starsi nez 1 mesic, ale ponechat alespon 3 posledni pro kazdy username (i kdyz budou treba starsi nez 1 mesic) Verim, ze uz to nekdo musel resit, ale asi se googlu spatne ptam :( Dekuji
DELETE starsi nez mesic EXCEPT (SELECT prvni tri starsi nez mesic pro kazdeho usera);
CREATE TABLE msg_log ( username VARCHAR(100) , msg TEXT(100) , created_at DATE ); CREATE INDEX idx_msg_log_created_at ON msg_log (username, created_at); INSERT INTO msg_log VALUES ('y', 'A', CURRENT_DATE - interval 6 month); INSERT INTO msg_log VALUES ('x', 'B', CURRENT_DATE - interval 5 month); INSERT INTO msg_log VALUES ('x', 'C', CURRENT_DATE - interval 4 month); INSERT INTO msg_log VALUES ('x', 'D', CURRENT_DATE - interval 4 month); INSERT INTO msg_log VALUES ('x', 'E', CURRENT_DATE - interval 4 month); INSERT INTO msg_log VALUES ('x', 'F', CURRENT_DATE - interval 3 month); INSERT INTO msg_log VALUES ('x', 'G', CURRENT_DATE - interval 2 month); INSERT INTO msg_log VALUES ('x', 'H', CURRENT_DATE - interval 1 month); INSERT INTO msg_log VALUES ('x', 'I', CURRENT_DATE - interval 1 day); INSERT INTO msg_log VALUES ('y', 'J', CURRENT_DATE); INSERT INTO msg_log VALUES ('z', 'K', CURRENT_DATE - interval 10 month); INSERT INTO msg_log VALUES ('z', 'L', CURRENT_DATE - interval 9 month); INSERT INTO msg_log VALUES ('z', 'M', CURRENT_DATE - interval 8 month); INSERT INTO msg_log VALUES ('z', 'N', CURRENT_DATE - interval 7 month); INSERT INTO msg_log VALUES ('z', 'O', CURRENT_DATE - interval 6 month); INSERT INTO msg_log VALUES ('z', 'P', CURRENT_DATE - interval 3 month); DELETE d FROM msg_log AS d WHERE d.username = 'z' AND d.created_at < ( SELECT min(x.created_at) min_ts FROM ( SELECT * FROM msg_log l WHERE l.created_at < CURRENT_DATE - interval 1 month AND l.username = 'z' ORDER BY l.created_at DESC LIMIT 3 ) x) ;...a volat to pre kazdeho usera zvlast (v priklade 'z'). tu je kompletny priklad pre PostgreSQL (testovane na 12.6):
CREATE TABLE msg_log ( username VARCHAR , msg TEXT , created_at DATE ; CREATE INDEX idx_msg_log_created_at ON msg_log (username, created_at); INSERT INTO msg_log VALUES ('y', 'A', current_date - interval '6 month'); INSERT INTO msg_log VALUES ('x', 'B', current_date - interval '5 month'); INSERT INTO msg_log VALUES ('x', 'C', current_date - interval '4 month'); INSERT INTO msg_log VALUES ('x', 'D', current_date - interval '4 month'); INSERT INTO msg_log VALUES ('x', 'E', current_date - interval '4 month'); INSERT INTO msg_log VALUES ('x', 'F', current_date - interval '3 month'); INSERT INTO msg_log VALUES ('x', 'G', current_date - interval '2 month'); INSERT INTO msg_log VALUES ('x', 'H', current_date - interval '1 month'); INSERT INTO msg_log VALUES ('x', 'I', current_date - interval '1 day'); INSERT INTO msg_log VALUES ('y', 'J', current_date); INSERT INTO msg_log VALUES ('z', 'K', current_date - interval '10 month'); INSERT INTO msg_log VALUES ('z', 'L', current_date - interval '9 month'); INSERT INTO msg_log VALUES ('z', 'M', current_date - interval '8 month'); INSERT INTO msg_log VALUES ('z', 'N', current_date - interval '7 month'); INSERT INTO msg_log VALUES ('z', 'O', current_date - interval '6 month'); INSERT INTO msg_log VALUES ('z', 'P', current_date - interval '3 month'); WITH users AS ( -- idealne mat ulozene v tabulke, na ktoru odkazuje cudzi kluc na msg_log(username) SELECT DISTINCT username FROM msg_log ), maxDateKeptPerUser AS ( SELECT u.username, ( SELECT min(x.created_at) FROM (SELECT * FROM msg_log l WHERE l.created_at < CURRENT_DATE - interval '1 month' AND l.username = u.username ORDER BY l.created_at DESC LIMIT 3 ) x ) AS created_at FROM users AS u ) DELETE FROM msg_log AS d USING maxDateKeptPerUser AS m WHERE d.username = m.username AND d.created_at < m.created_at ;
Tiskni Sdílej: