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 18:00 | Komunita

    Po dvaceti letech skončil leader japonské SUMO (SUpport.MOzilla.org) komunity Marsf. Důvodem bylo nasazení sumobota, který nedodržuje nastavené postupy a hrubě zasahuje do překladů i archivů. Marsf zároveň zakázal použití svých příspěvků a dat k učení sumobota a AI a požádal o vyřazení svých dat ze všech učebních dat.

    karkar | Komentářů: 1
    dnes 11:00 | IT novinky

    Úřad pro ochranu hospodářské soutěže zahajuje sektorové šetření v oblasti mobilních telekomunikačních služeb poskytovaných domácnostem v České republice. Z poznatků získaných na základě prvotní analýzy provedené ve spolupráci s Českým telekomunikačním úřadem (ČTÚ) ÚOHS zjistil, že vzájemné vztahy mezi operátory je zapotřebí detailněji prověřit kvůli možné nefunkčnosti některých aspektů konkurence na trzích, na nichž roste tržní podíl klíčových hráčů a naopak klesá význam nezávislých virtuálních operátorů.

    Ladislav Hagara | Komentářů: 8
    dnes 10:55 | Humor

    Různé audity bezpečnostních systémů pařížského muzea Louvre odhalily závažné problémy v oblasti kybernetické bezpečnosti a tyto problémy přetrvávaly déle než deset let. Jeden z těchto auditů, který v roce 2014 provedla francouzská národní agentura pro kybernetickou bezpečnost, například ukázal, že heslo do kamerového systému muzea bylo „Louvre“. 😀

    Ladislav Hagara | Komentářů: 9
    dnes 01:00 | Komunita

    Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.

    Ladislav Hagara | Komentářů: 13
    dnes 00:00 | IT novinky

    Byl publikován plán na odstranění XSLT z webových prohlížečů Chrome a Chromium. S odstraněním XSLT souhlasí také vývojáři Firefoxu a WebKit. Důvodem jsou bezpečnostní rizika a klesající využití v moderním webovém vývoji.

    Ladislav Hagara | Komentářů: 1
    včera 15:55 | Nová verze

    Desktopové prostředí LXQt (Lightweight Qt Desktop Environment, Wikipedie) vzniklé sloučením projektů Razor-qt a LXDE bylo vydáno ve verzi 2.3.0. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 05:55 | IT novinky

    Organizace Open Container Initiative (OCI) (Wikipedie), projekt nadace Linux Foundation, vydala Runtime Specification 1.3 (pdf), tj. novou verzi specifikace kontejnerového běhového prostředí. Hlavní novinkou je podpora FreeBSD.

    Ladislav Hagara | Komentářů: 0
    4.11. 11:33 | IT novinky

    Nový open source router Turris Omnia NG je v prodeji. Aktuálně na Allegro, Alternetivo, Discomp, i4wifi a WiFiShop.

    Ladislav Hagara | Komentářů: 22
    4.11. 05:44 | Komunita

    Na YouTube a nově také na VHSky byly zveřejněny sestříhané videozáznamy přednášek z letošního OpenAltu.

    Ladislav Hagara | Komentářů: 0
    4.11. 04:33 | Komunita

    Jednou za rok otevírá společnost SUSE dveře svých kanceláří široké veřejnosti. Letos je pro vás otevře 26. listopadu v 16 hodin v pražském Karlíně. Vítáni jsou všichni, kdo se chtějí dozvědět více o práci vývojářů, prostředí ve kterém pracují a o místní firemní kultuře. Můžete se těšit na krátké prezentace, které vám přiblíží, na čem inženýři v Praze pracují, jak spolupracují se zákazníky, partnery i studenty, proč mají rádi open source a co

    … více »
    SUSEMAS | Komentářů: 3
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (48%)
     (18%)
     (17%)
     (22%)
     (15%)
     (21%)
     (16%)
     (16%)
    Celkem 320 hlasů
     Komentářů: 15, poslední 2.11. 08:25
    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: 1275×
    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.