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

V únoru 2014 bylo hlasováním rozhodnuto, že výchozím init systémem v Debianu je systemd. V listopadu stejného roku bylo hlasováním rozhodnuto, že o podpoře dalších init systémů v Debianu není celoprojektové hlasování nutné. Po pěti letech už ale hlasování o init systémech a systemd nutné je. Vybírá se z 8 možností. Výsledek hlasování bude zveřejněn po 27. prosinci.

Ladislav Hagara | Komentářů: 18
včera 00:11 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot, se rozhodl, že svůj komiks vydá také knižně a ve vlastní režii. Komiks již knižně vyšel ve francouzštině ve vydavatelství Glénat. David Revoy jej vydá v angličtině a použije pouze svobodný software. O své zkušenosti se dělí ve dvou příspěvcích na svém blogu. Z plánovaných dvou týdnů práce se staly dva měsíce. Vydání před Vánocemi se nestihne. Kontrolní výtisk má příliš jasné barvy, obrázky v knihách od Glénatu vypadají mnohem lépe, …

Ladislav Hagara | Komentářů: 1
6.12. 20:44 | IT novinky

Mezinárodní konsorcium W3C (World Wide Web Consortium) vydalo verzi 1.0 základní specifikace WebAssembly a po HTML, CSS a JavaScriptu prohlásilo WebAssembly za čtvrtý oficiální jazyk pro web.

Ladislav Hagara | Komentářů: 7
6.12. 13:33 | Komunita

Hlasování o obrázku v okně O Inkscapu 1.0 pokračuje druhým kolem. Ze 124 obrázků postoupilo do finálního hlasování 5 s nejvíce hlasy. Výsledek hlasování bude zveřejněn po jeho ukončení, tj. po 15. prosinci.

Ladislav Hagara | Komentářů: 6
6.12. 02:11 | IT novinky

Společnost Purism představila mobilní telefon Librem 5 USA. Jedná se o telefon Librem 5 vyráběný v USA. Předobjednat jej lze za 1 999 dolarů. Librem 5 lze předobjednat za 699 dolarů.

Ladislav Hagara | Komentářů: 36
5.12. 22:22 | Nová verze

Příspěvek na blogu organizace Electronic Frontier Foundation (EFF) informuje, že Certbot, tj. oficiální klient certifikační autority Let’s Encrypt, dospěl do nové stabilní verze 1.0. Oficiálně tak byla ukončena beta fáze jeho vývoje. Certbot byl představen v květnu 2016.

Ladislav Hagara | Komentářů: 0
5.12. 15:55 | Zajímavý software

Mozilla vydala novou verzi 0.6 svobodného softwaru DeepSpeech pro převod řeči na text. Přehled novinek v příspěvku na blogu Mozilla Hacks.

Ladislav Hagara | Komentářů: 4
4.12. 17:33 | Zajímavý projekt

Dnes měl na YouTube premiéru krátký sci-fi film SKYWATCH. Colin Levy na něm strávil téměř 6 let. Pro vytvoření 3D grafiky byl vybrán Blender. Film byl z části financován z kampaně na Kickstarteru.

Ladislav Hagara | Komentářů: 3
4.12. 05:55 | Zajímavý software

Netflix uvolnil framework pro datovou vědu Metaflow jako open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí Apache 2.0.

Ladislav Hagara | Komentářů: 44
3.12. 21:33 | Nová verze

Byla vydána nová verze 4.1 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Opravena byla také řada bezpečnostních chyb.

Ladislav Hagara | Komentářů: 3
Jaké hodinky nosíte (nejčastěji)?
 (23%)
 (6%)
 (17%)
 (54%)
Celkem 514 hlasů
 Komentářů: 135, poslední 6.12. 20:54
Rozcestník

www.AutoDoc.Cz

Dotaz: MySQL update více polí dotazem

18.2. 11:14 Milan Uhrák | skóre: 28 | blog: milan_at_ABC
MySQL update více polí dotazem
Přečteno: 395×
Zdravím,

Chci aktualizovat ( nově přidané ) sloupce LastPlace a LastDate pomocí největší hodnoty Time ( a z odpovídajícího řádku PC_Hostname ).

Vypotil jsem ze sebe
UPDATE Disks set ( SELECT PC_Hostname AS LastPlace, Time AS LastDate 
FROM Collections WHERE DiskID = Disk.ID ORDER BY Time DESC LIMIT 1 )
Ale to asi není správná cesta.

Dokážu to udělat po jedné hodnotě, ale takto současně mi to nijak nevychází. Ani na netu jsem při hledání podobnou konstrukci neviděl.

Asi to takto nepůjde, nebo je cestička ?

Díky Milan

Řešení dotazu:


Odpovědi

18.2. 11:17 Milan Uhrák | skóre: 28 | blog: milan_at_ABC
Rozbalit Rozbalit vše Re: MySQL update více polí dotazem
Ještě oprava v dotazu namísto Disk má být Disks
18.2. 12:31 Milan Uhrák | skóre: 28 | blog: milan_at_ABC
Rozbalit Rozbalit vše Re: MySQL update více polí dotazem
Nakonec jsem "zaměstnal stroj" namísto hlavy ...
 
UPDATE Disks  SET 
     LastPlace = ( 
          SELECT PC_Hostname FROM Collections 
               WHERE Collections.DiskID = Disks.ID ORDER BY Collections.Time DESC LIMIT 1 
     ), 
     LastDate = ( 
          SELECT Time FROM Collections 
              WHERE Collections.DiskID = Disks.ID ORDER BY Collections.Time DESC LIMIT 1 
     ) ;

Není čas :)

Ale kdyby to někdo uměl tou hlavou, nechám se poučit

M.
Řešení 1× (Milan Uhrák (tazatel))
18.2. 12:54 Kit | skóre: 44 | Brno
Rozbalit Rozbalit vše Re: MySQL update více polí dotazem
Zkusím z hlavy:
UPDATE Disks AS D
    JOIN (SELECT DiskID, LastPlace, max(Time) AS LastDate
        FROM Collections GROUP BY DiskID) AS C
    ON D.ID=C.DiskID
    SET D.LastPlace=C.LastPlace,
        D.LastDate=C.LastDate;
Bez záruky.
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
18.2. 22:22 Milan Uhrák | skóre: 28 | blog: milan_at_ABC
Rozbalit Rozbalit vše Re: MySQL update více polí dotazem
Zato to vypadá slibně. Ráno určitě vyzkouším.

Děkuji za inspiraci

M.
20.2. 08:51 j
Rozbalit Rozbalit vše Re: MySQL update více polí dotazem
To ti fungovat nebude ;D ....

SELECT DiskID, LastPlace, max(Time) AS LastDate FROM Collections GROUP BY DiskID

Vynada ti to za ten LastPlace. Musis nejdriv zjistit ten max time a pak ho dat do join/where. A bude to fungovat jen za predpokladu, ze je pro konkretni DiskID unikatni.

Tzn nejdriv potrebujes

SELECT DiskID, max(Time) AS LastDate FROM Collections GROUP BY DiskID

A pak nejak tak (group uz netreba, cas mas)

SELECT DiskID, LastPlace, Time AS LastDate FROM Collections as x join ( SELECT DiskID, max(Time) AS LastDate FROM Collections GROUP BY DiskID) as t on t.DiskID = x.DiskID and t.LastDate = x.Time

Jo a btw, takovyhle veci vetsinou nejsou nijak uzasne rychly, spis presne naopak, takze to je spis takova prasecinka na jednorazovy pouziti.
20.2. 10:49 Milan Uhrák | skóre: 28 | blog: milan_at_ABC
Rozbalit Rozbalit vše Re: MySQL update více polí dotazem
Ahoj, díky, tohle je už fakt masakr, tohle bych nevypotil. Těch disků je tam asi 150, záznamů k nim asi 35000( už to nějakou dobu sleduju, no ).

Nakonec jsem to udělal po svém
 
UPDATE Disks  SET 
   LastPlace = ( 
      SELECT PC_Hostname FROM Collections WHERE Collections.DiskID = Disks.ID ORDER BY Collections.Time DESC LIMIT 1 
   ), 
   LastDate = ( 
      SELECT Time FROM Collections WHERE Collections.DiskID = Disks.ID ORDER BY Collections.Time DESC LIMIT 1 
   ) ;

Dotay opravdu není rychlý, ale svoje udělá.

Možná by to šlo přes temporary table ... ale tuhle cestu namám prošlapanou, nebudu to už ani zkoušet .. asi.
20.2. 10:54 Milan Uhrák | skóre: 28 | blog: milan_at_ABC
Rozbalit Rozbalit vše Re: MySQL update více polí dotazem
Díky, toto funguje... jen s úpravou JOIN (SELECT DiskID, PC_Hostname AS LastPlace, max(Time)
20.2. 11:02 Milan Uhrák | skóre: 28 | blog: milan_at_ABC
Rozbalit Rozbalit vše Re: MySQL update více polí dotazem
Tedy, Kite, tohle vypotit z hlavy, a ještě fungující ... no tedy poklona ...

Dotaz ( v PMA ) trval 0,8 sek. ( 150 disků, 35000 collections ).

Jsem ohromen :-)

Díky moc, mám se co učit

M.
20.2. 14:19 Kit | skóre: 44 | Brno
Rozbalit Rozbalit vše Re: MySQL update více polí dotazem
Díky za uznání, je to pro mne významným stimulem.
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.

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.