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 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

Ladislav Hagara | Komentářů: 0
dnes 02:02 | Komunita

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
včera 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

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

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
20.1. 17:00 | Nová verze

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 4
20.1. 15:51 | Komunita

Mozilla.cz informuje, že nástroje pro webové vývojáře se možná oddělí od Firefoxu a stanou doplňkem. Nástroje pro webové vývojáře prošly velkým přepisem a tým, který se stará o jejich vývoj, by uvítal možnost jejich častějších aktualizacích nezávisle na vydávání nových verzí Firefoxu.

Ladislav Hagara | Komentářů: 10
20.1. 07:00 | Humor

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
20.1. 06:00 | Komunita

Bylo spuštěno hlasování o přednáškách a workshopech pro letošní InstallFest, jenž proběhne o víkendu 4. a 5. března v Praze. Současně byla oznámena změna místa. InstallFest se letos vrací zpět na Karlovo náměstí do budovy E.

Ladislav Hagara | Komentářů: 0
20.1. 02:48 | Komunita

Greg Kroah-Hartman potvrdil, že Linux 4.9 je jádrem s prodlouženou upstream podporou (LTS, Long Term Support). Podpora je plánována do ledna 2019. Aktuální jádra s prodlouženou podporou jsou tedy 3.2, 3.4, 3.10, 3.12, 3.16, 3.18, 4.1, 4.4 a 4.9.

Ladislav Hagara | Komentářů: 0
20.1. 00:11 | Zajímavý článek

Výrobce síťových prvků, společnost Netgear, spustila nový program, který slibuje vývojářům, expertům, ale i běžným uživatelům vyplacení finanční odměny za nalezení bezpečnostních chyby v jejich produktech. Za nalezení zranitelnosti v hardware, API nebo mobilní aplikaci nabízí odměnu od 150 do 15 tisíc dolarů (dle závažnosti).

Michal Makovec | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 362 hlasů
 Komentářů: 25, poslední včera 13:34
Rozcestník
Reklama

Dotaz: Součet hodin po dnech

28.3.2013 14:56 hodza | skóre: 4 | Pňovice 244, 78401 Pňovice
Součet hodin po dnech
Přečteno: 1174×
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: 23 | 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: 4 | Pňovice 244, 78401 Pňovice
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: 4 | Pňovice 244, 78401 Pňovice
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.