Po po téměř roce vývoje od vydání verze 5.38 byla vydána nová stabilní verze 5.40 programovacího jazyka Perl (Wikipedie). Do vývoje se zapojilo 75 vývojářů. Změněno bylo přibližně 160 tisíc řádků v 1 500 souborech. Přehled novinek a změn v podrobném seznamu.
Uroš Popović popisuje, jak si nastavit Linux na desce jako Raspberry Pi Zero, aby je šlo používat jako USB „flešku“.
Andreas Kling oznámil, že jelikož už se nevěnuje nezávislému operačnímu systému SerenityOS, ale výhradně jeho webovému prohlížeči Ladybird, přičemž vyvíjí primárně na Linuxu, SerenityOS opustí a Ladybird bude nově samostatný projekt (nový web, repozitář na GitHubu).
Po dvou měsících vývoje byla vydána nová verze 0.13.0 programovacího jazyka Zig (GitHub, Wikipedie). Přispělo 73 vývojářů. Přehled novinek v poznámkách k vydání.
Na čem aktuálně pracují vývojáři GNOME a KDE? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE.
Před 70 lety, 7. června 1954, ve věku 41 let, zemřel Alan Turing, britský matematik, logik, kryptoanalytik a zakladatel moderní informatiky.
NiceGUI umožňuje používat webový prohlížeč jako frontend pro kód v Pythonu. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána ve verzi 2024.6. Z novinek lze vypíchnout lepší integraci LLM (OpenAI, Google AI, Ollama) nebo podporu Matter 1.3.
IKEA ve Spojeném království hledá zaměstnance do své nové pobočky. Do pobočky v počítačové hře Roblox. Nástupní mzda je 13,15 liber na hodinu.
Alyssa Rosenzweig se v příspěvku na svém blogu Vulkan 1.3 na M1 za 1 měsíc rozepsala o novém Vulkan 1.3 ovladači Honeykrisp pro Apple M1 splňujícím specifikaci Khronosu. Vychází z ovladače NVK pro GPU od Nvidie. V plánu je dále rozchodit DXVK a vkd3d-proton a tím pádem Direct3D, aby na Apple M1 s Asahi Linuxem běžely hry pro Microsoft Windows.
date("Y-m-d 0:0:0", strtotime("-2 days + ".$min." minutes"));což ale nefunguje, neboť to přičítá k základnímu času a až potom ořízne čas.
for($i=0;$i<$cas[count($cas)];$i++)a hledat
if(60 > ($cas[$i] - $cas[$i-1]) < 120)tím dostanete ty hodnoty co chcete, ostatním přiřadíte NULL. Samozřejmě, že to chce ošetřit začátek, kdy i = 0 a pak také nějak zyvšovat $cas[$i-1] o 60 pokud neni nalezen časový vzorek. Kdyžtak odpoledne mohu poslat kus kodu.
<?php $d1 = new DateTime('-2 days'); $d1 = new DateTime($d1->format('Y-m-d H:i:00')); $i1 = new DateInterval('PT1M'); for($i=0;$i<10;$i++) echo $d1->add($i1)->format('Y-m-d H:i:00'), "\n"; echo "\n",$d1->add(new DateInterval('PT1440M'))->format('Y-m-d H:i:00'), "\n";
SELECT DATE_FORMAT(NOW(),'%Y-%m-%d-%H:%i:00');
$today_start = date("Y-m-d 0:0:0", strtotime("-2 days")); $today_stop = date("Y-m-d 0:0:0", strtotime("+1 days")); $vysledek = mysql_query("SELECT cas,hum FROM mereni WHERE (cas > '$today_start') AND (cas < '$today_stop') ORDER BY cas"); while($zaznam = MySQL_Fetch_Array($vysledek)) { $cas[] = $zaznam['cas']; $hum[] = $zaznam['hum']; } $cas_old = strtotime($today_start); $j = 0; for($i=0;$i<count($hum);$i++){ $str_cas = strtotime($cas[$i]); if($str_cas >= ($cas_old + 60)){ if($str_cas < ($cas_old + 120)){ $hum2[$j] = $hum[$i]; $j++; $cas_old = $str_cas; } else{ while($str_cas >= ($cas_old + 120)) { $hum2[$j] = NULL; $j++; $cas_old += 60; } $hum2[$j] = $hum[$i]; $j++; $cas_old = $str_cas; } } }Zde uvádím pro přehlednost verzi bez ošetření případných chyb. V proměné $hum2 jsou naměřené hodnoty, které odpovídají od půlnoci předpředchozího do poslední měřené hodnoty, s krokem 1 minuta
Když si vytvořím testovací data:
CREATE TABLE t ( id int(11) NOT NULL auto_increment, d datetime DEFAULT NULL, data varchar(20) DEFAULT NULL, PRIMARY KEY (id) ); delimiter $$ CREATE PROCEDURE prepare_test_data() BEGIN DECLARE i INT DEFAULT 0; WHILE i < 8000 DO INSERT INTO t (d, data) VALUES (DATE_FORMAT(NOW() - INTERVAL i MINUTE, '%Y-%m-%d-%H:%i:00'),CONCAT('VAL:',i)); INSERT INTO tt (d, data) VALUES (DATE_FORMAT(NOW() - INTERVAL i MINUTE, '%Y-%m-%d-%H:%i:00'),CONCAT('VAL:',i)); SET i = i + 12; END WHILE; END$$ delimiter ; call prepare_test_data(); DROP PROCEDURE prepare_test_data; CREATE TABLE series ( id int(11) NOT NULL auto_increment, PRIMARY KEY (id) ); delimiter $$ CREATE PROCEDURE prepare_series_data() BEGIN DECLARE i INT DEFAULT 0; WHILE i < 4320 DO INSERT INTO series () VALUES(); SET i = i + 1; END WHILE; END$$ delimiter ; call prepare_series_data(); DROP PROCEDURE prepare_series_data;
Pokud jsou data již ukládána ze sekundama: 00 (je zvolen interval od NOW()
)
SELECT IFNULL(t.d,DATE_FORMAT(NOW() - INTERVAL series.id MINUTE,'%Y-%m-%d-%H:%i:00')) AS dt, t.data FROM series LEFT JOIN t ON t.d = CONVERT(DATE_FORMAT(NOW() - INTERVAL series.id MINUTE,'%Y-%m-%d-%H:%i:00'),DATETIME) ORDER BY series.id ASC;Za: 9.61 sec
Pokud NEjsou data již ukládána ze sekundama: 00 (je zvolen interval od NOW()
)
SELECT IFNULL(t.d,DATE_FORMAT(NOW() - INTERVAL series.id MINUTE,'%Y-%m-%d-%H:%i:00')) AS dt, t.data FROM series LEFT JOIN t ON CONVERT(DATE_FORMAT(t.d - INTERVAL series.id MINUTE,'%Y-%m-%d-%H:%i:00'),DATETIME) = CONVERT(DATE_FORMAT(NOW() - INTERVAL series.id MINUTE,'%Y-%m-%d-%H:%i:00'),DATETIME) ORDER BY series.id ASC;Za: 15.64 sec
Efektivní, ale odstranit duplicitu už efektivně neumím:
(SELECT d, data FROM t WHERE d > NOW() - INTERVAL 4320 MINUTE) UNION (SELECT DATE_FORMAT(NOW() - INTERVAL series.id MINUTE,'%Y-%m-%d %H:%i:00') AS d, NULL AS data FROM series) ORDER BY d ASC;Za: 0.02 sec Pominul jsem možnost udělat
temporary table
…
A nakonec uklidím:
DROP TABLE t; DROP TABLE series;
Když si vytvořím testovací data:
CREATE TABLE t ( id int(11) NOT NULL auto_increment, d datetime DEFAULT NULL, data varchar(20) DEFAULT NULL, PRIMARY KEY (id) ); delimiter $$ CREATE PROCEDURE prepare_test_data() BEGIN DECLARE i INT DEFAULT 0; WHILE i < 8000 DO INSERT INTO t (d, data) VALUES (DATE_FORMAT(NOW() - INTERVAL i MINUTE, '%Y-%m-%d-%H:%i:00'),CONCAT('VAL:',i)); SET i = i + 12; END WHILE; END$$ delimiter ; call prepare_test_data(); DROP PROCEDURE prepare_test_data; CREATE TABLE series ( id int(11) NOT NULL auto_increment, PRIMARY KEY (id) ); delimiter $$ CREATE PROCEDURE prepare_series_data() BEGIN DECLARE i INT DEFAULT 0; WHILE i < 4320 DO INSERT INTO series () VALUES(); SET i = i + 1; END WHILE; END$$ delimiter ; call prepare_series_data(); DROP PROCEDURE prepare_series_data;
Asi bys nepochopil jak jsem přemýšlel , myslel jsem že řešíš to co neumím vyřešit :).
Ono i tímto způsobem, který mě nevím proč nenapadl:
SELECT t1.d AS dt, t.data FROM (SELECT CONVERT(DATE_FORMAT(NOW() - INTERVAL series.id MINUTE,'%Y-%m-%d-%H:%i:00'),DATETIME) AS d FROM series) AS t1 LEFT JOIN t ON t.d = t1.d ORDER BY dt ASC;Mám 2.7 sec ale pokud si předgeneruji sérii do do pomocné tabulky tak dostávám 2.6 sec, takže dál to nelze.
Zatím vždy, když jsem řešil něco podobného, definoval jsem ID záznamové tabulky jako 'tick' v tomto případě minuta a měl jsem definovaný posun (tick nula se rovná tomuto datu-času) a při zakládání záznamu jsem spočítal tick z NOW() a prdl to do ID. Následný jakýkoliv join řady se děje nad INT a je to pohoda a šlahá to.
Tiskni Sdílej: