Na GOG.com běží Spring Sale. Při té příležitosti lze získat zdarma počítačovou hru Lorelai (ProtonDB).
Curl, řádkový nástroj a knihovna pro přenos dat po různých protokolech, slaví 25 let. Vydána byla nová verze 8.0.0. Mimo jiné řeší 6 zranitelností.
V sobotu 25. března proběhne Arduino Day 2023. Od 14:00 lze sledovat oficiální stream. Zúčastnit se lze i lokálních akcí. V Česku jsou aktuálně registrovány dvě: v Praze na Matfyzu a v Poličce v městské knihovně.
Fabrice Bellard, tvůrce FFmpeg nebo QEMU, představil TextSynth Server. Jedná se o webový server nabízející REST API k velkým AI jazykovým modelům. CPU verze je k dispozici zdarma jako binárka pod licencí MIT. GPU verze je komerční. Vyzkoušet lze na stránkách TextSynth.
Na konferenci LibrePlanet 2023 byly vyhlášeny ceny Free Software Foundation. Oceněni byli Eli Zaretskii za dlouhodobé příspěvky (správce Emacsu), Tad „SkewedZeppelin“ za nové příspěvky (správce DivestOS, distribuce Androidu) a projekt GNU Jami za společenský přínos.
Projekt Libreboot (Wikipedie) vydal novou verzi 20230319 svého svobodného firmwaru nahrazujícího proprietární BIOSy. Přibyla například podpora Lenovo ThinkPadů W530 a T530. Libreboot je distribucí Corebootu bez proprietárních blobů.
Na YouTube jsou k dispozici videozáznamy z 20. konference SCALE (Southern California Linux Expo). Závěrečnou přednášku měl dnes již osmdesátiletý Ken Thompson. Na otázku, jaký operační systém používá, odpověděl: "Většinu svého života jsem používal Apple, protože jsem se do této společnosti tak trochu narodil. Poslední dobou, myslím posledních pět let, jsem ale kvůli Applu více a více depresivní. To, co dělá s něčím, co by vám mělo umožnit
… více »Byla vydána verze 10.00 linuxové distribuce SystemRescue, původně SystemRescueCd, určené pro záchranu systémů a dat. Přehled novinek v changelogu. Linux byl povýšen na verzi 6.1.20.
Byla vydána verze 16.0.0 překladačové infrastruktury LLVM (Wikipedie). Přehled novinek v poznámkách k vydání: LLVM, Clang, LLD, Extra Clang Tools, Libc++ a Polly.
O víkendu probíhá v Bostonu, a také virtuálně, konference LibrePlanet 2023 organizovaná nadací Free Software Foundation (FSF).
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é. 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: