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 21:44 | Nová verze

Po roce vývoje od vydání verze 11.0 byla vydána nová verze 12.0 a krátce nato 12.0.1 open source alternativy GitHubu, tj. softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech, GitLab (Wikipedie). Představení nových vlastností v příspěvku na blogu.

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

Článek na webu OSTechNix ve stručnosti popisuje technologie „balení“ aplikací AppImage, Snap a Flatpak: jejich stěžejní vlastnosti a rozdíly mezi nimi. Text se nezabývá správci balíčků Guix či Nix, ani tradičními distribučními správci balíčků jako APT, YUM aj.

Fluttershy, yay! | Komentářů: 2
včera 11:00 | Zajímavý článek

Národní centrum kybernetické bezpečnosti aktualizovalo bezpečnostní doporučení pro síťové správce (pdf). Tato doporučení jsou nastavena tak, aby je bylo možné aplikovat pokud možno v každé instituci. Doporučení jsou opět rozdělena do tří základních částí: bezpečnost infrastruktury, bezpečnost stanic a serverů a bezpečnost uživatelů.

Ladislav Hagara | Komentářů: 8
včera 09:11 | Komunita

Nedávno byla představena publikační platforma people.kernel.org. Své zápisky zde mohou publikovat vývojáři jádra Linux. Řešení je postaveno na WriteFreely a Write.as.

Ladislav Hagara | Komentářů: 0
24.6. 12:11 | Nová verze

Byla vydána nová verze 2019-06-20 linuxové distribuce Raspbian určené především pro jednodeskové miniaturní počítače Raspberry Pi. Přehled novinek v příspěvku na blogu a v poznámkách k vydání. Společně s Raspbianem byl aktualizován také instalační nástroj NOOBS (New Out Of the Box Software). Nejnovější verze Raspbianu vychází z Debianu 10 s kódovým názvem Buster a přináší především podporu Raspberry Pi 4 Model B.

Ladislav Hagara | Komentářů: 1
24.6. 10:55 | Zajímavý článek

Vývojáři postmarketOS (GitLab) hodnotí dva roky vývoje tohoto v květnu 2017 představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky [reddit, Hacker News].

Ladislav Hagara | Komentářů: 0
24.6. 10:11 | IT novinky

Nadace Raspberry Pi na svém blogu oficiálně představila (YouTube) jednodeskový počítač Raspberry Pi 4 Model B. K dispozici je ve třech verzích: 1 GB, 2 GB a 4 GB RAM. Cena začíná na 35 dolarech za verzi s 1 GB RAM. Nejnovější Raspberry Pi podporuje 2 monitory a rozlišení 4K.

Ladislav Hagara | Komentářů: 29
23.6. 18:22 | Komunita

Oznámení, že Ubuntu od vydání 19.10 nebude distribuovat 32bitové balíčky (ani multilib) a uživatelé mohou použít virtualizaci či kontejnery LXD, se setkalo s vlnou nevole, mj. protože i řada 64bitových aplikací využívá 32bitový instalátor. Vývojáři Wine a Steamu oznámili, že zřejmě přestanou Ubuntu od vydání 19.10 podporovat. Diskuze na Redditu: [Wine], [Steam].

Fluttershy, yay! | Komentářů: 59
22.6. 16:11 | IT novinky

Nový open source Windows Terminal představený na vývojářské konferenci Microsoft Build 2019 lze již instalovat z Microsoft Store. Podrobnosti v příspěvku na blogu Microsoftu.

Ladislav Hagara | Komentářů: 11
21.6. 13:11 | Zajímavý projekt

Článek na OMG! Ubuntu! představuje projekt Wayfire, jehož cílem je vývoj kompozitního správce oken inspirovaného Compizem běžícího nad Waylandem. Videoukázky na YouTube. Zdrojové kódy na GitHubu.

Ladislav Hagara | Komentářů: 11
Jakou verzi jádra Linux typicky používáte na osobním počítači?
 (17%)
 (20%)
 (55%)
 (3%)
 (4%)
Celkem 363 hlasů
 Komentářů: 9, poslední 21.6. 14:42
Rozcestník

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: 379×
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: 43 | 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: 43 | 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.