V pátek 6. a sobotu 7. března proběhl v pražském sídle Nejvyššího kontrolního úřadu (NKÚ) Hackathon veřejné správy 7.1. Publikovány byly vytvořené aplikace. V kategorii projektů rozvíjených z krajského kola zvítězil tým „Mackokládi“. Čtyři středoškoláci ze Dvora Králové uspěli s aplikací KompaZ. Jde o digitálního průvodce, který pomůže s rychlou a srozumitelnou orientací v životních i krizových situacích „krok za krokem“. Aplikace
… více »QGIS, svobodný desktopový GIS, byl vydán v nové hlavní verzi 4.0. Změny zahrnují několik nových analytických a editačních funkcí, rozšíření podpory 3D, více možností úprav uživatelského rozhraní či mnoho dalších zlepšení použitelnosti. Řada 3.44 má aktualizace plánovány do září.
Dan Blanchard vydal knihovnu pro Python chardet v nové verzi 7.0.0. S novou verzí byla knihovna přelicencována z LGPL na MIT. Souhlasili s tím všichni přispěvatelé? Dan Blanchard souhlasy vůbec neřešil. Zaúkoloval umělou inteligenci (Claude), aby knihovnu zcela přepsala a výslovně jí nařídil, aby nepoužila žádný LGPL kód. Dan Blanchard tvrdí, že se jedná o clean room design. Protistrana argumentuje, že umělá inteligence byla trénována
… více »Andy Nguyen si na svou herní konzoli PlayStation 5 (PS5) pomocí exploitu Byepervisor nainstaloval Linux (Ubuntu). V Linuxu si spustil Steam a PS5 tak proměnil v Steam Machine. Na PS5 může hrát hry, které jsou vydané pouze pro PC a jsou na Steamu [Tom's Hardware].
Správce sbírky fotografií digiKam byl vydán ve verzi 9.0.0. Jedná se o větší vydání provázené aktualizacemi knihoven. Mnoho dílčích změn se vedle oprav chyb týká uživatelského rozhraní, mj. editace metadat.
Byla vydána verze 2026 distribuce programu pro počítačovou sazbu TeX s názvem TeX Live (Wikipedie). Přehled novinek v oficiální dokumentaci.
Jihokorejská Národní daňová služba (NTS) zabavila kryptoměnu Pre-retogeum (PRTG) v hodnotě 5,6 milionu dolarů. Pochlubila se v tiskové zprávě, do které vložila fotografii zabavených USB flash disků s kryptoměnovými peněženkami spolu se souvisejícími ručně napsanými mnemotechnickými obnovovacími frázemi. Krátce na to byla kryptoměna v hodnotě 4,8 milionu dolarů odcizena. O několik hodin ale vrácena, jelikož PRTG je extrémně nelikvidní, s denním objemem obchodování kolem 332 dolarů a zalistováním na jediné burze, MEXC [Bitcoin.com].
Komunita kolem Linuxu From Scratch (LFS) vydala nové verze knih s návody na instalaci vlastního linuxového systému ze zdrojových kódů Linux From Scratch 13.0 a Beyond Linux From Scratch 13.0. Pouze se systemd.
Byla vydána nová stabilní major verze 25.12 linuxové distribuce primárně určené pro routery a vestavěné systémy OpenWrt (Wikipedie). Jedná se o nástupce předchozí major verze 24.10. Přehled novinek v poznámkách k vydání. Podporováno je více než 2200 zařízení.
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za únor (YouTube). Odstraněn byl veškerý kód napsaný ve Swiftu. JavaScriptový engine LibJS byl reimplementován v Rustu.
Interpreti: (pk) id_interpreta | jmeno | zanr (FK) Skladby: (pk)id_skladby | (fk)id_interpreta | (fk) id_interpret_spolu_s |nazev_skladby Zanry: (pk)id_zanru | nazev_zanruPotřebuji mít stav, že v interpreti.zanr bude víc záznamů. Napadlo mě, že se to řeší více 1řádkovými záznamy v tabulce Interpreti, příklad:
1 | Karel Gott | pop 1 | Karel Gott | jiný žánrAle to potom nemohu u id_interpreta použít auto_increment.
Řešení dotazu:
1 | Karel Gott | pop 1 | Karel Gott | jiný žánrAsi potřebujete tohle, a není to relace 1:n, nýbrž m:n :
tabulka interpreti interpret_id | interpret_jmeno 1 | Karel Gott tabulka zanry zanr_id | zanr_jmeno 1 | pop 2 | folk tabulka interpreti_zanry id | interpret_id | zanr_id 1 | 1 | 1 2 | 1 | 2 (fk) interpreti(interpret_id) (fk) zanry(zanr_id)
interprets ---------- id (PK) | name 1 | Karel Gott 2 | Atka Janouskova 3 | Alicia Keys genres ------ id (PK)| title pop | Pop folk | Folk rnb | Rhythm&Blues interpret2genre --------------- interpret | genre 1 | pop 1 | folk 2 | pop 3 | rnb (pk) interpret, genre (fk) interprets(interpret) (fk) genres(genre)
CREATE TABLE interprets (
id NUMBER(16) PRIMARY KEY,
name VARCHAR2(128)
);
CREATE TABLE genres (
id VARCHAR2(16) PRIMARY KEY,
title VARCHAR2(64) NOT NULL
);
CREATE TABLE interpret2genre (
interpret NUMBER(16)
CONSTRAINT fk_interpret2genre_interpret
REFERENCES interprets
ON DELETE CASCADE,
genre VARCHAR2(16)
CONSTRAINT fk_interpret2genre_genre
REFERENCES genres
ON DELETE CASCADE,
CONSTRAINT pk_interpret2genre
PRIMARY KEY (interpret, genre)
);
SELECT `interpreti`.`interpret_jmeno` AS 'Interpret', `skladby`.`skladba_nazev` AS 'Název skladby', `zanry`.`zanr_jmeno` AS 'Žánr' FROM `interpreti_zanry`, `interpreti`, `zanry`, `skladby`, `interpreti_skladby` WHERE `interpreti_zanry`.`interpret_id`=`interpreti`.`interpret_id` AND `interpreti_zanry`.`zanr_id`=`zanry`.`zanr_id` AND `interpreti_skladby`.`skladba_id`=`skladby`.`skladba_id` AND `interpreti_skladby`.`interpret_id`=`interpreti`.`interpret_id`;mám záznamy:
Karlova_píseň_1 | Karel Gott | žánr1 Karlova_píseň_1 | Karel Gott | žánr2Umím si zobrazit vše:
$radku=mysql_num_rows($vysledek);
if ($radku==0) echo "nic tu neni";
else
{
while ($zaznam=MySQL_Fetch_Array($vysledek)):
echo $zaznam["Interpret"]."
\n";
echo $zaznam["Název skladby"]."
\n";
echo $zaznam["Žánr"]."
\n";
endwhile;
}
Ale přemýšlím, jak tam zakopomnovat ten druhý cyklus, který by vyzvednul ve třetím sloupci data a hodil je na jeden řádek... Prosím o naťuknutí, dodělám si to pak sám...
Ještě jednou díky (je to fanouškovskej web, ne úkol do školy).
SELECT interpret_jmeno, skladba_nazev, zanr_jmeno
FROM interpreti JOIN interpreti_zanry USING(interpret_id)
JOIN zanry USING(zanr_id)
JOIN interpreti_skladby USING(interpret_id)
JOIN skladby USING(skladba_id);
Predpokladam ze stejna skladba muze vyslovne patrit k vice interpretum - v opacnem pripade je tabulka interpreti_skladby zbytecna, misto ni by se dal interpret_id do tabulky skladby.
Karel Gott | Když muž se ženou snídá | pop Karel Gott | Když muž se ženou snídá | rock Karel Gott | Když muž se ženou snídá | bluesjá ale chci:
Karel Gott | Když muž se ženou snídá | pop, rock, bluesPotřebuji přistupovat do toho třetího sloupce a vypsat tam všechny žánry. Chápu, že by šlo, vyzjistit kolik dotaz vygeneroval řádků a tam udělat dlouhý for cyklus a spojovat obsahy z třetího sloupce. Ale já potřebuju vypsat 30 posledních přidaných skladeb. Napadá mě udělat si pomocnou funkci, která tyto žánry spojí pro jednu skladbu, ale není mi jasné jak rozlišovat jestli jsem u Káji nebo jinde. Opět lepší příklad, než slova:
function ma_funkce($kolik_radku){
// tato funkce u 3 radku Karel Gott vytahuje ze 3. sloupce zanry a haze je do jednoho radku
//zvladne to i u Kabátů a 5 žánrů
}
$radku=mysql_num_rows($dotaz);
if ($radku==0) echo "nic tu neni";
else
{
while ($zaznam=MySQL_Fetch_Array($vysledek)):
echo $zaznam["Interpret"]."
\n";
echo $zaznam["Název skladby"]."
\n";
echo $zaznam["Žánr"]."
\n";
endwhile;
}
No a já potřebuji vymyslet tu podmínku u while, aby rozlišovala, že tam je teď 3x Karel Gott, tak zavolej má_funkce(3) nebo pro Kabáty má_funkce(5).
Za JOIN díky.
ano, je přeci možné, aby jedna skladba měla více interpretů (zpívá: X feat Y). Dotaz jsem myslel takto: příklad PHP kódu jenž jsem dodal vypíše obsah spojených tabulek v toto tvaru:Co takhle:Karel Gott | Když muž se ženou snídá | pop Karel Gott | Když muž se ženou snídá | rock Karel Gott | Když muž se ženou snídá | bluesjá ale chci:Karel Gott | Když muž se ženou snídá | pop, rock, blues
SELECT interpret_jmeno, skladba_nazev, GROUP_CONCAT(zanr_jmeno)
FROM interpreti JOIN interpreti_skladby USING(interpret_id)
JOIN skladby USING(skladba_id)
JOIN interpreti_zanry USING(interpret_id)
JOIN zanry USING(zanr_id)
GROUP BY interpret_id, skladba_id;
BTW, neměl by žánr patřit spíše ke skladbě než k interpretovi?
SELECT i.id_interpreta, i.jmeno,
GROUP_CONCAT(DISTINCT z.nazev_zanru SEPARATOR ', ') AS zanry
FROM interpreti i
LEFT JOIN Skladby s ON s.id_interpreta = i.id_interpreta
LEFT JOIN Zanry z ON z.id_zanru = s.id_zanru
GROUP BY i.id_interpreta
Dobrý den, navrhuji si pro svůj malý webík databázi a potřebuji 1:N relace.Na nějaké studování joinů bych se "pro svůj malý webík" vykašlal, a místo toho použil rovnou nějaký ORM framework. Tam si jen řeknete jak mají vypadat objekty (záznamy) a starost o schema v DB jakož i insert/select/update/delete odpadá.
Tiskni
Sdílej: