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 16:11 | IT novinky

    Americký výrobce čipů AMD uzavřel s americkou společností OpenAI smlouvu na několikaleté dodávky vyspělých mikročipů pro umělou inteligenci (AI). Součástí dohody je i předkupní právo OpenAI na přibližně desetiprocentní podíl v AMD.

    Ladislav Hagara | Komentářů: 0
    dnes 12:22 | Nová verze Ladislav Hagara | Komentářů: 0
    včera 20:00 | Komunita

    Byly zpracovány a na YouTube zveřejněny videozáznamy z konference LinuxDays 2025.

    Ladislav Hagara | Komentářů: 0
    4.10. 15:22 | IT novinky

    Na konferenci LinuxDays 2025 byl oficiálně představen nový router Turris Omnia NG.

    Ladislav Hagara | Komentářů: 30
    4.10. 05:22 | Komunita

    Přímý přenos (YouTube) z konference LinuxDays 2025, jež probíhá tento víkend v Praze v prostorách FIT ČVUT. Na programu je spousta zajímavých přednášek.

    Ladislav Hagara | Komentářů: 14
    3.10. 22:44 | IT novinky

    V únoru loňského roku Úřad pro ochranu osobních údajů pravomocně uložil společnosti Avast Software pokutu 351 mil. Kč za porušení GDPR. Městský soud v Praze tuto pokutu na úterním jednání zrušil. Potvrdil ale, že společnost Avast porušila zákon, když skrze svůj zdarma dostupný antivirový program sledovala, které weby jeho uživatelé navštěvují, a tyto informace předávala dceřiné společnosti Jumpshot. Úřad pro ochranu osobních údajů

    … více »
    Ladislav Hagara | Komentářů: 9
    3.10. 19:00 | Nová verze

    Google Chrome 141 byl prohlášen za stabilní. Nejnovější stabilní verze 141.0.7390.54 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 21 bezpečnostních chyb. Za nejvážnější z nich (Heap buffer overflow in WebGPU) bylo vyplaceno 25 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    3.10. 17:11 | Upozornění

    eDoklady mají kvůli vysoké zátěži technické potíže. Ministerstvo vnitra doporučuje vzít si sebou klasický občanský průkaz nebo pas.

    Ladislav Hagara | Komentářů: 33
    3.10. 17:00 | Komunita

    Novým prezidentem Free Software Foundation (FSF) se stal Ian Kelling.

    Ladislav Hagara | Komentářů: 1
    3.10. 14:33 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za září (YouTube).

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (38%)
     (45%)
     (16%)
     (17%)
     (22%)
     (15%)
     (18%)
     (16%)
     (16%)
    Celkem 179 hlasů
     Komentářů: 12, poslední 4.10. 20:35
    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: 1265×
    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.