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í
×
    včera 18:22 | Nová verze

    Byla vydána verze 0.2.0 v Rustu napsaného frameworku Pingora pro vytváření rychlých, spolehlivých a programovatelných síťových systémů. Společnost Cloudflare jej letos v únoru uvolnila pod licencí Apache 2.0.

    Ladislav Hagara | Komentářů: 0
    10.5. 19:11 | Nová verze

    Open source RDP (Remote Desktop Protocol) server xrdp (Wikipedie) byl vydán ve verzi 0.10.0. Z novinek je vypíchnuta podpora GFX (Graphic Pipeline Extension). Nová větev řeší také několik bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 7
    10.5. 04:11 | Nová verze

    Rocky Linux byl vydán v nové stabilní verzi 9.4. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    9.5. 22:22 | Bezpečnostní upozornění

    Dellu byla odcizena databáze zákazníků (jméno, adresa, seznam zakoupených produktů) [Customer Care, Bleeping Computer].

    Ladislav Hagara | Komentářů: 17
    9.5. 21:11 | Zajímavý článek

    V lednu byl otevřen editor kódů Zed od autorů editoru Atom a Tree-sitter. Tenkrát běžel pouze na macOS. Byl napevno svázán s Metalem. Situace se ale postupně mění. V aktuálním příspěvku Kdy Zed na Linuxu? na blogu Zedu vývojáři popisují aktuální stav. Blíží se alfa verze.

    Ladislav Hagara | Komentářů: 32
    9.5. 14:33 | Pozvánky

    O víkendu 11. a 12. května lze navštívit Maker Faire Prague, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.

    Ladislav Hagara | Komentářů: 0
    8.5. 21:55 | Nová verze

    Byl vydán Fedora Asahi Remix 40, tj. linuxová distribuce pro Apple Silicon vycházející z Fedora Linuxu 40.

    Ladislav Hagara | Komentářů: 20
    8.5. 20:22 | IT novinky

    Představena byla služba Raspberry Pi Connect usnadňující vzdálený grafický přístup k vašim Raspberry Pi z webového prohlížeče. Odkudkoli. Zdarma. Zatím v beta verzi. Detaily v dokumentaci.

    Ladislav Hagara | Komentářů: 7
    8.5. 12:55 | Nová verze

    Byla vydána verze R14.1.2 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.

    JZD | Komentářů: 0
    7.5. 18:55 | IT novinky

    Dnešním dnem lze již také v Česku nakupovat na Google Store (telefony a sluchátka Google Pixel).

    Ladislav Hagara | Komentářů: 10
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (64%)
     (7%)
     (13%)
     (16%)
    Celkem 161 hlasů
     Komentářů: 11, poslední 10.5. 18:00
    Rozcestník

    Dotaz: Součet hodin po dnech

    28.3.2013 14:56 hodza | skóre: 8 | Olomouc
    Součet hodin po dnech
    Přečteno: 1238×
    Ahoj, potřeboval bych nakopnout s následujícím problémem:

    Mám tabulku několika desítek aut - řekněme:

    CREATE TABLE IF NOT EXISTS `cars` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `registration_number` text CHARACTER SET utf8 COLLATE utf8_czech_ci NOT NULL,
      `name` text CHARACTER SET utf8 COLLATE utf8_czech_ci NOT NULL
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;

    Která je spojená s tabulkou seznamu jízd (cars.id = car_requests.car_id) - řekněme:

    CREATE TABLE IF NOT EXISTS `car_requests` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `car_id` int(11) NOT NULL COMMENT 'ID auta',
      `date_from` datetime NOT NULL COMMENT 'Datum od',
      `date_to` datetime NOT NULL COMMENT 'Datum do',
      PRIMARY KEY (`id`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COLLATE=utf8_czech_ci AUTO_INCREMENT=1 ;

    Co potřebuji je výstup ve kterém budou uvedeny jednotlivé dny v měsící a ke každému dni bude pro každé auto uvedeno kolik hodin bylo v daný den zapůjčeno. Napadá někoho nějaké jednoduché řešení (čtěte SELECT)?

    Použitá DB je MySQL 5.xx

    Řešení dotazu:


    Odpovědi

    28.3.2013 15:16 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: Součet hodin po dnech
    No vzhledem k tomu, že se nemůže překrývat doba zapůjčení, tak je to vceluku jednoduché,
    SELECT 
      DATE(car_requests.date_from), 
      cars.registration_number,
      SUM(TO_SECONDS(car_requests.date_to) - TO_SECONDS(car_requests.date_from)) / (60 * 60)
    FROM 
      cars 
        LEFT JOIN car_requests ON car.id = car_requests.car_id
    GROUP BY 
      1,2
    
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    Řešení 1× (hodza (tazatel))
    29.3.2013 10:05 kaaja | skóre: 24 | blog: Sem tam něco | Podbořany, Praha
    Rozbalit Rozbalit vše Re: Součet hodin po dnech

    Tohle není úplně správně. Když bude auto zapůjčeno více než den, tak to vrátí jen první den a více než 24 hodin a pro další dny to nevrátí nic. Jediné opravdu správné řešení je mít tabulku dnů a s ní to správně spojovat.

    Mohlo by fungovat něco jako (select píšu pouze schématicky, úplně se mi nechce ho ladit a nemá mysql) :

     

    select   
    car_requests.car_id, 
    dny.datum,
       sum (
    min(dny.datum+1, car_requests.date_to) - 
    max(dny.datum, car_requests.date_from)
     )    
    from car_requests 
    inner join dny on dny.datum <= car_requests.date_to and dny.datum + 1 >= car_requests.date_from 
    group by car_requests.car_id, dny.datum
    1.4.2013 12:21 hodza | skóre: 8 | Olomouc
    Rozbalit Rozbalit vše Re: Součet hodin po dnech
    Díky. Prozkoumám. Jinak na ladění db kterou nemám je dobrý např.: http://sqlfiddle.com/
    1.4.2013 12:22 hodza | skóre: 8 | Olomouc
    Rozbalit Rozbalit vše Re: Součet hodin po dnech
    Díky za příspěvek, nicméně tak jak píše kolega dole - není to správně.
    28.3.2013 15:43 kuka
    Rozbalit Rozbalit vše Re: Součet hodin po dnech
    viz http://www.abclinuxu.cz/poradna/databaze/show/373991#7

    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.