Společnost Backblaze zveřejnila statistiky spolehlivosti pevných disků používaných ve svých datových centrech za rok 2025. Ke konci roku 2025 vlastnila 349 462 pevných disků. Průměrná AFR (Annualized Failure Rate), tj. pravděpodobnost, že disk během roku selže, byla 1,36 %. V roce 2024 to bylo 1,57 %. V roce 2023 to bylo 1,70 %. V roce 2022 to bylo 1,37 %.
Nástroj sql-tap je proxy mezi aplikací a databází, které zachytává všechny SQL dotazy a zobrazuje je v terminálovém rozhraní. Zde lze téměř v reálném čase zkoumat dotazy, sledovat transakce a spouštět SQL příkaz EXPLAIN. Podporované databázové systémy jsou pouze PostgreSQL a MySQL. Zdrojový kód je dostupný na GitHubu, pod licencí MIT.
Byla vydána nová verze 9.2 textového editoru Vim (Vi IMproved). Přináší vylepšené doplňování, podporu schránky ve Waylandu, podporu XDG Base Directory (konfigurace v $HOME/.config/vim), vylepšené Vim9 skriptování nebo lepší zvýrazňování změn. Vim zůstává charityware. Nadále vybízí k podpoře dětí v Ugandě. Z důvodu úmrtí autora Vimu Brama Moolenaara a ukončení činnosti jím založené charitativní organizace ICCF Holland projekt Vim navázal spolupráci s charitativní organizaci Kuwasha.
Byl představen editor MonoSketch, webová aplikace pro tvorbu diagramů, technických nákresů, flowchartů a různých dalších vizualizací, to vše jenom z ASCII znaků. Všechny operace běží pouze v prohlížeči uživatele a neprobíhá tedy žádné nahrávání dat na server. Zdrojový kód aplikace (drtivá většina Kotlin, žádné C#) je dostupný na GitHubu pod licencí Apache 2.0.
Byla vydána nová verze 3.7.0 multiplatformního svobodného frameworku pro zpracování obrazu G'MIC (GREYC's Magic for Image Computing, Wikipedie). Přehled novinek i s náhledy nových filtrů na PIXLS.US.
Všem na AbcLinuxu vše nejlepší k Valentýnu aneb Dni lásky ke svobodnému softwaru (I love Free Software Day, Mastodon, 𝕏).
Eric Migicovsky představil Pebble Emulator, tj. emulátor hodinek Pebble (PebbleOS) běžící ve webovém prohlížeči. Za 6 hodin jej napsal Claude Code. Zdrojové kódy jsou k dispozici na GitHubu.
Byla vydána nová verze 3.41 frameworku Flutter (Wikipedie) pro vývoj mobilních, webových i desktopových aplikací a nová verze 3.11 souvisejícího programovacího jazyka Dart (Wikipedie).
Rusko zcela zablokovalo komunikační platformu WhatsApp, řekl včera mluvčí Kremlu Dmitrij Peskov. Aplikace, jejímž vlastníkem je americká společnost Meta Platforms a která má v Rusku na 100 milionů uživatelů, podle Peskova nedodržovala ruské zákony. Mluvčí zároveň lidem v Rusku doporučil, aby začali používat domácí aplikaci MAX. Kritici tvrdí, že tato aplikace ruské vládě umožňuje lidi sledovat, což úřady popírají.
Před 34 lety, ve čtvrtek 13. února 1992, se tehdejší Česká a Slovenská Federativní Republika oficiálně (a slavnostně) připojila k Internetu.
jmeno | banka | vklad --------------------- jan KB 100 jan CSOB 200 jan CS 100 tonda CSOB 100 tonda CS 100 pepa KB 300 jiri KB 200 jiri CSOB 100Chtěl bych docílit toho, aby každý člověk měl v ČS uloženo 100 Kč. Umím vypsat, kteří lidé nemají u ČS nic:
select distinct jmeno from moje_tabulka
where jmeno not in (select jmeno from moje_tabulka where banka <> 'CS')
Výsledkem by měl být pepa, jiriAle už nevím, jak toto použít pro INSERT. Finální tabulka by měla vypadat takto:
jmeno | banka | vklad --------------------- jan KB 100 jan CSOB 200 jan CS 100 tonda CSOB 100 tonda CS 100 pepa KB 300 pepa CS 100 jiri KB 200 jiri CSOB 100 jiri CS 100Děkuji za rady. JR
Řešení dotazu:
banka = 'CS' v subselecte
ak mas otestovany select, potom staci pouzit insert-select syntax:
INSERT INTO moje_tabulka (jmeno, banka, vklad)
SELECT DISTINCT jmeno, 'CS', 100
FROM moje_tabulka
WHERE jmeno NOT IN (SELECT jmeno FROM moje_tabulka WHERE banka = 'CS')
;
Odhlédnu od toho, že to schéma je špatně navržené, a budu to brát jako minimalistický příklad pro potřeby dotazu.
Soubor vklady.sql:
CREATE TABLE vklad (
jmeno VARCHAR(20),
banka VARCHAR(10),
vklad INTEGER
);
INSERT INTO vklad (jmeno, banka, vklad) VALUES ('jan', 'KB', 100);
INSERT INTO vklad (jmeno, banka, vklad) VALUES ('jan', 'CSOB', 200);
INSERT INTO vklad (jmeno, banka, vklad) VALUES ('jan', 'CS', 100);
INSERT INTO vklad (jmeno, banka, vklad) VALUES ('tonda', 'CSOB', 100);
INSERT INTO vklad (jmeno, banka, vklad) VALUES ('tonda', 'CS', 100);
INSERT INTO vklad (jmeno, banka, vklad) VALUES ('pepa', 'KB', 300);
INSERT INTO vklad (jmeno, banka, vklad) VALUES ('jiri', 'KB', 200);
INSERT INTO vklad (jmeno, banka, vklad) VALUES ('jiri', 'CSOB', 100);
INSERT INTO vklad (jmeno, banka, vklad)
SELECT
jmeno,
'CS' AS banka,
100 AS vklad
FROM (
SELECT
jmeno
FROM vklad
EXCEPT
SELECT
jmeno
FROM vklad
WHERE banka = 'CS'
);
Výsledek:
$ cat vklady.sql | relpipe-in-sql --relation vklad "SELECT * FROM vklad" | relpipe-out-tabular vklad: ╭────────────────┬────────────────┬─────────────────╮ │ jmeno (string) │ banka (string) │ vklad (integer) │ ├────────────────┼────────────────┼─────────────────┤ │ jan │ KB │ 100 │ │ jan │ CSOB │ 200 │ │ jan │ CS │ 100 │ │ tonda │ CSOB │ 100 │ │ tonda │ CS │ 100 │ │ pepa │ KB │ 300 │ │ jiri │ KB │ 200 │ │ jiri │ CSOB │ 100 │ │ jiri │ CS │ 100 │ │ pepa │ CS │ 100 │ ╰────────────────┴────────────────┴─────────────────╯ Record count: 10
Tiskni
Sdílej: