abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 0
dnes 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
včera 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 8
včera 15:30 | Zajímavý projekt

Společnost Jolla oznámila v příspěvku Case study: Sailfish Watch na svém blogu, že naportovala Sailfish OS na chytré hodinky. Využila a inspirovala se otevřeným operačním systémem pro chytré hodinky AsteroidOS. Použita je knihovna libhybris. Ukázka ovládání hodinek na YouTube.

Ladislav Hagara | Komentářů: 8
včera 14:15 | Nová verze

Byla vydána verze 7.1.0 skriptovacího jazyka PHP používaného zejména k vývoji dynamických webových stránek. Jedná se o první stabilní verzi nejnovější větvě 7.1. Přehled novinek v dokumentaci. Podrobnosti v ChangeLogu. K dispozici je také příručka pro přechod z PHP 7.0.x na PHP 7.1.x.

Ladislav Hagara | Komentářů: 2
včera 12:55 | Nová verze

Google Chrome 55 byl prohlášen za stabilní. Nejnovější stabilní verze 55.0.2883.75 tohoto webového prohlížeče přináší řadu oprav a vylepšení (YouTube). Opraveno bylo také 36 bezpečnostních chyb. Mariusz Mlynski si například vydělal 22 500 dolarů za 3 nahlášené chyby (Universal XSS in Blink).

Ladislav Hagara | Komentářů: 4
včera 11:55 | Pozvánky

Máte rádi svobodný software a hardware nebo se o nich chcete něco dozvědět? Přijďte na 135. sraz spolku OpenAlt, který se bude konat ve čtvrtek 8. prosince od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Sraz bude tentokrát tématický. Bude retro! K vidění budou přístroje jako Psion 5mx nebo Palm Z22. Ze svobodného hardwaru pak Openmoko nebo čtečka WikiReader. Přijďte se i vy pochlubit svými legendami, nebo alespoň na pivo. Moderní hardware má vstup samozřejmě také povolen.

xkucf03 | Komentářů: 0
včera 00:10 | Nová verze

Byla vydána verze 3.2 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata. Z novinek lze zmínit například podporu protokolů DNP3 a CIP/ENIP, vylepšenou podporu TLS a samozřejmě také aktualizovanou dokumentaci.

Ladislav Hagara | Komentářů: 0
1.12. 21:00 | Nová verze

Byla vydána beta verze Linux Mintu 18.1 s kódovým jménem Serena. Na blogu Linux Mintu jsou hned dvě oznámení. První o vydání Linux Mintu s prostředím MATE a druhé o vydání Linux Mintu s prostředím Cinnamon. Stejným způsobem jsou rozděleny také poznámky k vydání (MATE, Cinnamon) a přehled novinek s náhledy (MATE, Cinnamon). Linux Mint 18.1 bude podporován až do roku 2021.

Ladislav Hagara | Komentářů: 0
1.12. 16:42 | Nová verze

Byl vydán Devuan Jessie 1.0 Beta 2. Jedná se o druhou beta verzi forku Debianu bez systemd představeného v listopadu 2014 (zprávička). První beta verze byla vydána v dubnu letošního roku (zprávička). Jedna z posledních přednášek věnovaných Devuanu proběhla v listopadu na konferenci FSCONS 2016 (YouTube, pdf).

Ladislav Hagara | Komentářů: 0
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 763 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: Grafy v PHP z MySQL

10.9.2013 19:12 Pavel | skóre: 16
Grafy v PHP z MySQL
Přečteno: 1411×
Zdravím, mám aplikaci, která každou minutu ukládá data do DB. Na serveru generuju v php grafy a zobrazuji průběhy za předchozí 3 dni od půlnoci do půlnoci. Dělám to tak, že vyčtu data z DB a předám je pro graf, to funguje výborně, problém je, když se v datech udělá hodinová mezera. Tímto způsobem jí nezjistím. Chci udělat nějakou funkci která by do mezer zapsala hodnoty NULL, ať již zpětně do DB, nebo pokaždé při vykreslení grafu. Mělo by to vypadat nějak takto:

- inkrementuj minuty od datumu now()-3 day zaokrouhleno na dni - pro každou minutu doplň data z databáze, není li v DB hodnota uložena, použij NULL -vykresli graf

Nejjednodušší by bylo ošetřit to přímo v aplikaci, která data ukládá, ale potřebuji aby to fungovalo i když server vypadne, takže musím ty data kontrolovat až zpětně. Primárně mi tedy jde o to najít funkci, která k základnímu datumu přičte počet minut. Něco jako
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.

Odpovědi

10.9.2013 20:51 NN
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Zkusil bych to jinak, nezapisoval bych data z aplikace primo do databaze, ale napsal bych jednoduchy wrapper, ktery bude kazdou minutu cekat na odezvu od apliace.
10.9.2013 21:16 Pavel | skóre: 16
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Ano, to jsem psal, ale jak zajistim, aby po výpadku el. energie byly data správně? Spustit vždy při startu script který doplní null do všech časů které nebudou v DB?

Toto řešení je ale na dlouho, protože data dostávám z url adresy pomocí get. Když bych to přeci jen chtěl dělat až zpětně, jak udělat, aby mi funkce date("Y-m-d 0:0:0", strtotime("-2 days")) vrátila počet vteřin právě k té půlnoci? Ta funkce nejprve odečte 2 dni a až pak ořízne čas, to právě potřebuji opačně.
11.9.2013 02:02 vojakp
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
A co takhle? Vyčíst čas a hodnoty z databáze do pole. Projít pole č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.
11.9.2013 23:40 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Lze dostat z DB plnou číselnou řadu, džojnováním vůči pomocné tabulce obsahující číselnou řadu, ale pro takový rozsah a vůči sloupci DATETIME na je to velmi-velmi časově náročné.
Jinak chápu co chceš na vásledku, ale nevím jak toho chceš dosáhnout, tak nějaké inspirační ukázky:
<?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');
To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
12.9.2013 01:00 Pavel | skóre: 16
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Děkuji všem za radu, nakonec jsem to udělal takto:
$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
rADOn avatar 12.9.2013 15:03 rADOn | skóre: 44 | blog: bloK | Praha
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Proc to nenajoinujes na casy jak psal sangala vyse? Usetris spoustu kodu a NULLy ti tam budou padat samy.
"2^24 comments ought to be enough for anyone" -- CmdrTaco
12.9.2013 17:14 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Ono smolit v PHP není moc výhra, nicméně to co jsem psal udělat nad sloupcem DATETIME neumím rychle a efektivně. Jak to lze udělat efektivně, víš?.

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;

To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
12.9.2013 17:46 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Nějak jsem vložil nepromazanou fci prepare_test_data() - druhý insert tam nepatří, tedy znovu celý první blok:

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;

To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
rADOn avatar 12.9.2013 18:53 rADOn | skóre: 44 | blog: bloK | Praha
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Genitalni napad:

Na hodiny a minuty a sekundy staci mit tabule s 24 a 60 radkama, najoinovat a z toho uz time nejakou funkci upatlas. Denni rozsahy uz by byly zakernejsi, nejspis bych to zbrutalnil jedenacti unionama. Porad lepsi nez to psat v php :-P
"2^24 comments ought to be enough for anyone" -- CmdrTaco
rADOn avatar 12.9.2013 19:11 rADOn | skóre: 44 | blog: bloK | Praha
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Vlastne kdyz v tabuli z mesicema bude pocet dni tak se to prihodi do podminky joinu a obejde se to bez unionu. Prestupny roky se vyzehli zvlast, beztak je to zraly na view… Cili z tabule o sedesati radcich se da zkonstruovat libovolny rozsah dat.
"2^24 comments ought to be enough for anyone" -- CmdrTaco
12.9.2013 20:49 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Napiš to, nepobral jsem jak se vyhneš parsování DATETIME v klausuli ON, nebo jej tak minimalizovat, že to nebude mít dopad na výkon.
To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
rADOn avatar 13.9.2013 16:58 rADOn | skóre: 44 | blog: bloK | Praha
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Joinujes jednotlivy slozky casu, na DATETIME prevedes az vystup. Kdyz chci dejme tomu vsechny minuty ve dni:

SELECT MAKETIME(hod.id, min.id, 0), hod.id, min.id FROM mod60 min JOIN mod60 hod ON hod.id < 24 order by hod.id, min.id;

Kdyz bys chtel i vteriny, staci pridat join. At zije kartezsky soucin :-) Vykon by mel byt v poho pokud databaze bude dost chytra aby nevyrabela radky mimo rozsah ktery si z toho vyberes.
"2^24 comments ought to be enough for anyone" -- CmdrTaco
13.9.2013 20:45 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL

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.

To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
rADOn avatar 18.9.2013 17:19 rADOn | skóre: 44 | blog: bloK | Praha
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Já s tím joinováním na souvislou řadu nepolemizuju, jen mě napadlo jestli by se to nechalo udělat bez předžvýkaný tabulky.
"2^24 comments ought to be enough for anyone" -- CmdrTaco
Josef Kufner avatar 14.9.2013 17:39 Josef Kufner | skóre: 66
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Btw, DATETIME není pro potřebu logování vůbec vhodné, neboť neumí časová pásma. Použij TIMESTAMP. Až se bude měnit čas ze zimního na letní nebo zpět, tak to oceníš. Musíš si jen dát pozor, aby jak MySQL, tak PHP pracovaly ve stejném časovém pásmu, a to Europe/Prague, nikoliv +2 nebo +1 hodina.

Ad vyplňování mezer: Netrap tím databázi a detekuj je při kreslení grafu. Pokud použiješ javascriptové zobrazovadlo, např. Flot, ušetříš si výkon na serveru.
Hello world ! Segmentation fault (core dumped)
15.9.2013 15:03 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Opravdu si myslíš, že doplnění serie/řady je lepší až na úrovní scriptu.
Obvykle tedy ty řady/série chci mít úplné z DB, a to s jedinou výjimkou a to jsou právě tyto datumovočasové řady tohoto charakteru, kde nelze jednoduchou posloupností to dát dohromady.
OT: A už jsem si vzpomněl proč mám všude u MySQL TIMESTAMP - dík ;-)
To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
Josef Kufner avatar 15.9.2013 16:53 Josef Kufner | skóre: 66
Rozbalit Rozbalit vše Re: Grafy v PHP z MySQL
Ta data nejsou nijak poškozená, jen prostě chybí. Tím, že je doplníš až na konci ušetříš výkon všude po cestě. Udělat vykreslovací algoritmus tak, aby sám počítal tiky na ose a dohledával data z dodané děravé tabulky je snadné.
Hello world ! Segmentation fault (core dumped)

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267   www.czech-server.cz
© 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.