abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    25.5. 19:00 | Zajímavý projekt

    Na crowdsourcingové platformě Crowd Supply byla spuštěna kampaň na podporu open source biometrického monitoru ve tvaru hodinek HealthyPi Move. Cena je 249 dolarů a plánovaný termín dodání listopad letošního roku.

    Ladislav Hagara | Komentářů: 11
    24.5. 22:22 | Upozornění Ladislav Hagara | Komentářů: 9
    24.5. 17:44 | Nová verze

    Firma Murena představila /e/OS verze 2.0. Jde o  alternativní sestavení Androidu bez aplikací Google. Mezi novinkami je podrobnější nastavení ochrany soukromí před sledováním aplikacemi. Murena prodává několik smartphonů s předinstalovaným /e/OS (Fairphone, repasovaný Google Pixel 5).

    Fluttershy, yay! | Komentářů: 0
    24.5. 14:33 | Zajímavý software

    Do 30. května lze v rámci akce Warhammer Skulls 2024 získat na Steamu zdarma hru Warhammer 40,000: Gladius - Relics of War.

    Ladislav Hagara | Komentářů: 1
    24.5. 13:33 | Nová verze

    HelenOS (Wikipedie), tj. svobodný operační systém českého původu založený na architektuře mikrojádra, byl vydán ve verzi 0.14.1. Přehled novinek v poznámkách k vydání. Vypíchnou lze nabídku Start. Videopředstavení na YouTube.

    Ladislav Hagara | Komentářů: 3
    23.5. 23:22 | Zajímavý software

    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.

    Ladislav Hagara | Komentářů: 0
    23.5. 16:55 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 13
    23.5. 12:55 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 0
    22.5. 23:44 | Pozvánky

    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í.

    Ladislav Hagara | Komentářů: 0
    22.5. 16:33 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (88%)
     (3%)
     (5%)
     (5%)
    Celkem 787 hlasů
     Komentářů: 16, poslední 14.5. 11:05
    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: 1124×
    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.