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í
×
    dnes 13:44 | Komunita

    Bylo spuštěno hlasování o přednáškách a workshopech pro letošní Installfest, jenž proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13.

    Ladislav Hagara | Komentářů: 1
    dnes 04:33 | Nová verze

    Byla vydána (Mastodon, 𝕏) třetí RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.

    Ladislav Hagara | Komentářů: 0
    včera 21:44 | IT novinky

    Apple představil iPhone 17e a iPad Air s čipem M4.

    Ladislav Hagara | Komentářů: 8
    včera 21:11 | Zajímavý software

    Byla vydána verze 1.0 editoru kódů Gram. Jedná se o fork editoru Zed bez telemetrie a umělé inteligence.

    Ladislav Hagara | Komentářů: 0
    včera 20:33 | IT novinky

    Byla oznámena spolupráce GrapheneOS s Motorolou. Podrobnosti v tiskové zprávě. GrapheneOS (Wikpedie) je varianta Androidu zaměřující se na bezpečnost a soukromí.

    Ladislav Hagara | Komentářů: 0
    včera 02:22 | Nová verze

    Armbian, tj. linuxová distribuce založená na Debianu a Ubuntu optimalizovaná pro jednodeskové počítače na platformě ARM a RISC-V, ke stažení ale také pro Intel a AMD, byl vydán ve verzi 26.2.1. Přehled novinek v Changelogu.

    Ladislav Hagara | Komentářů: 0
    včera 02:11 | Komunita

    Volí se dvě místa v Radě openSUSE. Seznamte se se čtyřmi kandidáty. Členové projektu openSUSE mohou hlasovat od 1. do 8. března. Výsledky budou oznámeny 9. března.

    lkocman | Komentářů: 3
    1.3. 19:22 | IT novinky

    Společnost OpenAI uzavřela dohodu s americkým ministerstvem obrany o poskytování technologií umělé inteligence (AI) pro utajované sítě americké armády. Firma to oznámila několik hodin poté, co prezident Donald Trump nařídil vládě, aby přestala využívat služby společnosti Anthropic.

    Ladislav Hagara | Komentářů: 12
    1.3. 13:33 | IT novinky

    Technologická společnost Anthropic v noci na dnešek oznámila, že se obrátí na soud kvůli rozhodnutí ministerstva obrany označit ji za bezpečnostní riziko dodavatelského řetězce poté, co nevyhověla jeho požadavkům týkajícím se používání umělé inteligence (AI). Prezident Donald Trump krátce před tím uvedl, že nařídil federálním úřadům postupně ukončit využívání jejích AI technologií. Spor mezi firmou vyvíjející chatbot Claude a

    … více »
    Ladislav Hagara | Komentářů: 15
    28.2. 15:44 | Upozornění

    Zemřel Rob Grant, spolutvůrce kultovního sci-fi seriálu Červený trpaslík.

    Ladislav Hagara | Komentářů: 8
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (7%)
     (0%)
     (12%)
     (27%)
     (2%)
     (5%)
     (2%)
     (13%)
     (25%)
    Celkem 998 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: MariaDB výpočet dení (a hodinové) spotřeby

    24.8.2015 12:36 DrNo
    MariaDB výpočet dení (a hodinové) spotřeby
    Přečteno: 1191×
    Zravím

    K monitoringu spotřeby elektřiny jsem vytahl z elektromeru (přes LEDku co signalizuje odběr, S0 vystup je zaplombován a přenos z rozvaděče na kraji pozemku mám vyřešený bezdrátově) a hodnoty ukládám do MariaDB měří a uládá se každé 2 minuty v tabulce je dalších několik hodnot na které je to akorád.
    datetime	        EL_celkem      AD1..
    2015-08-24 11:44:01	419.533	       xxxx..
    2015-08-24 11:42:01	419.533        xxxx..
    2015-08-24 11:40:01	419.534        xxxx..
    
    dotazem
    SELECT * FROM `tabulka` WHERE `datetime` LIKE '%20%%-%%-%% %%:00%' ORDER BY `datetime` DESC LIMIT 24
    
    nebo
    SELECT * FROM `tabulka` WHERE `datetime` LIKE '%20%%-%%-%% 00:00%' ORDER BY `datetime` DESC LIMIT 31
    
    datetime	        EL_celkem      AD1..
    2015-08-24 00:00:01	419.533	       xxxx..
    2015-08-23 00:00:01	409.413        xxxx..
    2015-08-22 00:00:01	403.741        xxxx..
    
    dostanu stavy elektroměru po hodinových nebo po denních přírůstcích.

    A tady jsem se zasekl a proto prosím o radu jak ty přírůstky sečíst a dostat hodnoty spotřeby za hodinu nebo za den.

    Stejný dotaz jsem našel na http://www.abclinuxu.cz/poradna/databaze/show/396499 akorád s vodoměrem a PostgreSQL.

    Bohužel na otázku rADOna umi neco takovyho mysql? byla Pokud vím, tak ne. Musel by jste si pomoci cursorem. A to je něco co netuším co je a nedokážu to vygooglovat, nejsem programátor ale elektronik a nemůžu s tím hnout. Děkuji

    Odpovědi

    24.8.2015 14:41 NN
    Rozbalit Rozbalit vše Re: MariaDB výpočet dení (a hodinové) spotřeby
    Neco jako:
    select sum(EL_celkem) from table where `datetime` ..
    24.8.2015 15:02 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: MariaDB výpočet dení (a hodinové) spotřeby
    Spotřeba za den
    SELECT 
      DATE_FORMAT(`datetime`, "%d.%m.%Y") AS `Den`, 
      MAX(EL_celkem) - MIN(EL_celkem) AS `Spotřeba` 
    FROM 
      tabulka 
    GROUP BY 
      1
    ;
    
    Spotřeba za hodinu
    SELECT 
      DATE_FORMAT(`datetime`, "%d.%m.%Y") AS `Den`,
      CONCAT(DATE_FORMAT(MIN(`datetime`), "%h:%i"), " - ", DATE_FORMAT(MAX(`datetime`), "%h:%i")) AS `Hodiny`,
      MAX(EL_celkem) - MIN(EL_celkem) AS `Spotřeba` 
    FROM 
     tabulka
    GROUP BY 
      DATE_FORMAT(`datetime`, "%d.%m.%Y %h")
    ;
    
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    24.8.2015 15:44 NN
    Rozbalit Rozbalit vše Re: MariaDB výpočet dení (a hodinové) spotřeby
    Hm, no mozek nezaregistroval, ze se jedna o prirustky ;) ..
    25.8.2015 12:23 DrNo
    Rozbalit Rozbalit vše Re: MariaDB výpočet dení (a hodinové) spotřeby
    Děkuji moc! i všem ostatním za náměty.
    24.8.2015 21:33 Denny
    Rozbalit Rozbalit vše Re: MariaDB výpočet dení (a hodinové) spotřeby
    Jestli se to má zpracovávat v databázi tak by šlo přidat si sloupec spotřeba a napsat trigger, který vždy po vložení dopočítá spotřebu mezi nově odečtenou hodnotou a tou z předchozího zápisu. A pak volat select s group by a sum(spotreba).

    případně tady je neefektivní, neelegatní, hloupoučká a potencionálně chybová procedura, která teoreticky dělá něco obdobnýho:
    CREATE PROCEDURE p()
    BEGIN
    
      CREATE TEMPORARY TABLE `tmp` AS SELECT * FROM `tabulka`;
      ALTER TABLE `tmp` ADD `EL_den_pred` DECIMAL(10,4) NOT NULL AFTER `EL_celkem`;
      ALTER TABLE `tmp` ADD `spotreba` DECIMAL(10,4) NOT NULL AFTER `EL_den_pred`;
      UPDATE `tmp` p SET p.`EL_den_pred` = (SELECT t.`EL_celkem`  FROM `tabulka` t WHERE t.`datetime` = p.`datetime` - INTERVAL 1 DAY );
      UPDATE `tmp` SET `spotreba` = (`EL_celkem` - `EL_den_pred`);
    
      SELECT YEAR(`datetime`), MONTH(`datetime`), SUM(`spotreba`) FROM `tmp` WHERE 1 GROUP BY DATE_FORMAT(`datetime`, '%Y%m');
      SELECT  * FROM `tmp`;
    END //

    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.