Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 141 (pdf) a HackSpace 78 (pdf).
Byla vydána verze 2.0.0 programovacího jazyka Kotlin (Wikipedie, GitHub). Oficiálně bude představena ve čtvrtek na konferenci KotlinConf 2024 v Kodani. Livestream bude možné sledovat na YouTube.
Byla vydána nová major verze 27.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Přehled novinek v příspěvku na blogu.
Byla vydána nová verze 1.8.0 svobodného multiplatformního softwaru pro konverzi video formátů HandBrake (Wikipedie). Přehled novinek v poznámkách k vydání na GitHubu. Instalovat lze také z Flathubu.
Microsoft představil nové označení počítačů Copilot+. Dle oznámení se jedná se o počítače poskytující funkce umělé inteligence. Vedle CPU a GPU mají také NPU (Neural Processing Unit). Uvnitř představených Copilot+ notebooků běží ARM čipy Qualcomm Snapdragon X Elite nebo X Plus.
Příspěvek na blogu Codean Labs rozebírá zranitelnost CVE-2024-4367 v PDF.js, tj. mj. prohlížeči PDF souborů ve Firefoxu. Při otevření útočníkem připraveného pdf souboru může být spuštěn libovolný kód v JavaScriptu. Vyřešeno ve Firefoxu 126.
Lazygit byl vydán ve verzi 0.42.0. Jedná se o TUI (Text User Interface) nadstavbu nad gitem.
K open source herní konzole Picopad přibyla (𝕏) vylepšená verze Picopad Pro s větším displejem, lepšími tlačítky a větší baterii. Na YouTube lze zhlédnout přednášku Picopad - open source herní konzole z LinuxDays 2023.
Byla vydána (𝕏) nová major verze 17 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í i s náhledy a videi v oficiálním oznámení.
Sovereign Tech Fund, tj. program financování otevřeného softwaru německým ministerstvem hospodářství a ochrany klimatu, podpoří vývoj FFmpeg částkou 157 580 eur. V listopadu loňského roku podpořil GNOME částkou 1 milion eur.
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: