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 19:55 | Nová verze

Po dvou letech od vydání verze 3.0 byla vydána nová major verze 4.0 nástrojů LXC, LXD a LXCFS pro kontejnerovou virtualizaci LXC (LinuX Containers). Jedná se o verzi s dlouhodobou podporou (LTS). Ta končí v červnu 2025. Přehled novinek v jednotlivých oznámeních o vydání: LXC, LXD a LXCFS.

Ladislav Hagara | Komentářů: 0
dnes 16:11 | Humor

Řada firem své letošní již připravené aprílové žertíky kvůli SARS-CoV-2 a COVID-19 nezveřejnila. Přehled zveřejněných například na April Fools' Day On The Web. Na CoinMarketCapu byla přidána nová kryptoměna: toaleťáky. Ve hře World of Tanks jsou vylepšené tanky, v PUBG nový herní mód Fantasy Battle Royale, …

Ladislav Hagara | Komentářů: 3
dnes 15:22 | Zajímavý projekt

Komunity KDE a GNOME, které doposud vyvíjely příslušná desktopová prostředí, se rozhodly přestat tříštit síly a představují společný projekt KNOME, který nabídne konfigurovatelnost GNOME a jednoduchost KDE v jednom balíčku. Staví na technologiích QTK3 a Kutter.

Fluttershy, yay! | Komentářů: 15
dnes 14:11 | Nová verze

Tradičně na apríla byla vydána nová stabilní verze OpenTTD (Wikipedie), tj. open source klonu hry Transport Tycoon Deluxe. Přehled novinek v nejnovější verzi 1.10.0 v seznamu změn. Starší verzi OpenTTD lze vyzkoušet také v prohlížeči.

Ladislav Hagara | Komentářů: 0
dnes 06:00 | Nová verze

Po čtyřech a půl měsících vývoje od vydání verze 5.3 byla vydána nová verze 5.4 svobodného open source redakčního systému WordPress. Kódové označení Adderley bylo vybráno na počest amerického jazzového trumpetisty Nata Adderleyho.

Ladislav Hagara | Komentářů: 0
včera 23:44 | IT novinky

Association for Computing Machinery vzhledem k probíhající pandemii COVID-19 nabízí bezplatný přístup do databáze publikací ACM Digital Library, a to do 30. června 2020.

Fluttershy, yay! | Komentářů: 2
včera 23:11 | IT novinky

Humble Bundle nabízí balík her (některých multiplatformních a/nebo bez DRM), knih, komiksů,… za cenu alespoň €28. Akce Humble Conquer COVID-19 Bundle probíhá do 7. dubna. Výtěžek bude věnován humanitárním/charitativním organizacím Lékaři bez hranic, Direct Relief, International Rescue Committee a Partners In Health.

Fluttershy, yay! | Komentářů: 7
včera 18:44 | Komunita

Český LibreOffice tým vydává překlad příručky LibreOffice Online. Příručka vznikla překladem anglického originálu, který byl vytvořen v rámci projektu Google Season of Docs 2019. Příručka je ke stažení na českých stránkách LibreOffice. Český tým pokračuje s překladem příručky Začínáme s LibreOffice a hledá další dobrovolníky pro překlad z angličtiny a revize přeloženého textu.

Zdeněk Crhonek | Komentářů: 0
včera 17:55 | Nová verze

Theia je nové modulární vývojové prostředí (IDE) určené k běhu jako webová aplikace a modifikovatelné pomocí doplňků kompatibilních s MS Visual Studio Code. Vývoj zaštiťuje Eclipse Foundation. Více v oznámení vydání verze 1.0.

Fluttershy, yay! | Komentářů: 1
včera 17:44 | Upozornění

V souvislosti s nedávnými kybernetickými útoky na nemocniční zařízení v České republice nabídl Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) ve spolupráci se sdružením CZ.NIC, správcem české národní domény a provozovatelem Národního bezpečnostního týmu CSIRT.CZ, pomoc klíčovým zdravotnickým subjektům, na které se vztahuje reaktivní opatření NÚKIB.

Ladislav Hagara | Komentářů: 2
Chodíte do práce?
 (12%)
 (0%)
 (4%)
 (0%)
 (62%)
 (23%)
 (0%)
Celkem 26 hlasů
 Komentářů: 1, poslední dnes 14:40
Rozcestník

www.AutoDoc.Cz

Dotaz: MySQL update více polí dotazem

18.2.2019 11:14 Milan Uhrák | skóre: 29 | blog: milan_at_ABC
MySQL update více polí dotazem
Přečteno: 410×
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.2019 11:17 Milan Uhrák | skóre: 29 | 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.2019 12:31 Milan Uhrák | skóre: 29 | 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.2019 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.2019 22:22 Milan Uhrák | skóre: 29 | 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.2019 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.2019 10:49 Milan Uhrák | skóre: 29 | 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.2019 10:54 Milan Uhrák | skóre: 29 | 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.2019 11:02 Milan Uhrák | skóre: 29 | 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.2019 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.