Yocto Project byl vydán ve verzi 5.0. Její kódové jméno je Scarthgap. Yocto Project usnadňuje vývoj vestavěných (embedded) linuxových systémů na míru konkrétním zařízením. Cílem projektu je nabídnou vývojářům vše potřebné. Jedná se o projekt Linux Foundation.
Operační systém 9front, fork operačního systému Plan 9, byl vydán v nové verzi "do not install" (pdf). Více o 9front v FQA.
Svobodná webová platforma pro sdílení a přehrávání videí PeerTube (Wikipedie) byla vydána v nové verzi 6.1. Přehled novinek i s náhledy v oficiálním oznámení a na GitHubu. Řešeny jsou také 2 bezpečnostní chyby.
Lennart Poettering na Mastodonu představil utilitu run0. Jedná se o alternativu k příkazu sudo založenou na systemd. Bude součástí systemd verze 256.
Hudební přehrávač Amarok byl vydán v nové major verzi 3.0 postavené na Qt5/KDE Frameworks 5. Předchozí verze 2.9.0 vyšla před 6 lety a byla postavená na Qt4. Portace Amaroku na Qt6/KDE Frameworks 6 by měla začít v následujících měsících.
Byla vydána nová verze 2.45.0 distribuovaného systému správy verzí Git. Přispělo 96 vývojářů, z toho 38 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání. Vypíchnout lze počáteční podporu repozitářů, ve kterých lze používat SHA-1 i SHA-256.
Před 25 lety, ve čtvrtek 29. dubna 1999, byla spuštěna služba "Úschovna".
Byla vydána nová verze 24.04.28 s kódovým názvem Time After Time svobodného multiplatformního video editoru Shotcut (Wikipedie) a nová verze 7.24.0 souvisejícího frameworku MLT Multimedia Framework. Nejnovější Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.
Byla vydána verze 5.30 dnes již open source operačního systému RISC OS (Wikipedie).
SELECT timediff(now(), a.close_time) AS estimate , p.nazov_t, a.start_price, a.start_price+sum(b.bid) AS actprice, a.* FROM app_aukcia a right join tovar p ON a.id_tovar=p.id JOIN app_aukcia_bids b ON b.id_aukcia=a.id WHERE a.closed='n' ORDER BY close_time DESC;ďakujem pekne
Řešení dotazu:
left OUTER join app_aukcia_bidsnebo mozna
right outer
, s timhle vzdycky trochu bojuju
SELECT SUM(b.bid) AS spolu,a.* FROM app_aukcia a LEFT OUTER JOIN app_aukcia_bids b on b.id_aukcia=a.id WHERE a.closed='n' ORDER BY close_time DESC;teraz sa to správa tak isto, teda zobrazuje iba riadky, pri ktorých je v druhej tabulke bid
OUTER
nemá na vykonávání joinů vliv; je prostě nepovinné.
Zadruhé: Rozdíl mezi LEFT [ OUTER ] JOIN
a RIGHT [ OUTER ] JOIN
:
LEFT JOIN
: to, pro co napravo od klauzule neexistuje odpovídající entita, je nahrazeno NULL
y.
RIGHT JOIN
: to, pro co nalevo od klauzule — tedy řídící množina je ta napravo — neexistuje odpovídající entita, je nahrazeno NULL
y.
FULL OUTER JOIN
, kde jsou řídícími množinami obě strany. Pak se lze v dokumentaci dočíst o CROSS JOIN
, což je kartézský součin.
INNER JOIN
, což znamená: dej mi to, co je vlevo a zároveň v pravo. Co na libovolné straně přebývá, zahoď.
GROUP BY
klauzule, byť MySQL (a potažmo i do určité míry i SyBase ASE) ji odpouští. To ale na věci nic nemění. Uvádět se má. Když ji vynecháš, databáze si groupuje jak chce — to znamená, že ztrácíš kontrolu.
OK, rozeberme si ten dotaz:a.start_price
versus a.*
. Hvězdička je jen pro ten nejtvrdší devel.TOVAR
, protože RIGHT JOIN
. K ní se dohledají aukce. Pak to celé omezíš (JOIN
znamená INNER JOIN
!) těmi přihozeními.
NULL
stejně jako operátory. To znamená, že 1 + NULL
je prostě NULL
. A i tak SUM()
NULL
ů je NULL
. Takže když k NULL
u vráceným agregační funkcí přičteš konstantu, výsledek je NULL
. NULL
ový výstup agrgační funkce se tedy musí převést na nějakou hodnotu.
Tím končím.
V příloze máš skript (ano, pro Oracle, protože tu nic jiného nemám), který by ti mohl být užitečný. Víc dát nemůžu, protože jsi neposkytnul testovací data.
P.S.: V diskuzi uvádíš, že ti nefunguje ani dotaz jen nad tabulkami aukcí a přihozeními. Zkontroluj si integritu dat. Tyhle primitivní spojení fungují i v Excelu a Accessu!
Tiskni Sdílej: