Spoluzakladatel a předseda správní rady americké softwarové společnosti Oracle Larry Ellison vystřídal spoluzakladatele automobilky Tesla a dalších firem Elona Muska na postu nejbohatšího člověka světa. Hodnota Ellisonova majetku díky dnešnímu prudkému posílení ceny akcií Oraclu odpoledne vykazovala nárůst o více než 100 miliard dolarů a dosáhla 393 miliard USD (zhruba 8,2 bilionu Kč). Hodnota Muskova majetku činila zhruba 385 miliard dolarů.
Bylo vydáno Eclipse IDE 2025-09 aneb Eclipse 4.37. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
T-Mobile od 15. září zpřístupňuje RCS (Rich Communication Services) zprávy i pro iPhone.
Společnost ARM představila platformu Arm Lumex s Arm C1 CPU Cluster a Arm Mali G1-Ultra GPU pro vlajkové chytré telefony a počítače nové generace.
Unicode Consortium, nezisková organizace koordinující rozvoj standardu Unicode, oznámila vydání Unicode 17.0. Přidáno bylo 4 803 nových znaků. Celkově jich je 159 801. Přibylo 7 nových Emoji.
Apple představil (YouTube) telefony iPhone 17 Pro a iPhone 17 Pro Max, iPhone 17 a iPhone Air, sluchátka AirPods Pro 3 a hodinky Watch Series 11, Watch SE 3 a Watch Ultra 3.
Realtimová strategie Warzone 2100 (Wikipedie) byla vydána ve verzi 4.6.0. Podrobný přehled novinek, změn a oprav v ChangeLogu na GitHubu. Nejnovější verzi Warzone 2100 lze již instalovat také ze Snapcraftu a Flathubu.
Polské vývojářské studio CD Projekt Red publikovalo na Printables.com 3D modely z počítačové hry Cyberpunk 2077.
Organizátoři konference LinuxDays 2025 vydali program a zároveň otevřeli registrace. Akce se uskuteční 4. a 5. října na FIT ČVUT v pražských Dejvicích, kde vás čekají přednášky, workshopy, stánky a spousta šikovných lidí. Vstup na akci je zdarma.
Uživatelé komunikátoru Signal si mohou svá data přímo v Signalu bezpečně zálohovat a v případě rozbití nebo ztráty telefonu následně na novém telefonu obnovit. Zálohování posledních 45 dnů je zdarma. Nad 45 dnů je zpoplatněno částkou 1,99 dolaru měsíčně.
Ahoj, mam nasledujucu qwery:
SELECT policy_table.user_group_name, policy_table.object_spec_desc, policy_table.action_spec_desc, policy_table.object_specification, service_type_action.service_type_name, service_type_action.action_name FROM policy_table LEFT JOIN service_type_action ON policy_table.action_specification = service_type_action.service_action_id;
z ktorej vypis je nasledujuci:
user_group_name | object_spec_desc | action_spec_desc | object_specification | service_type_name | action_name -----------------+------------------+------------------+----------------------+-------------------+------------- superUserGroup | user | serviceAction | bob | cas | grantAll analytici | userGroup | serviceAction | analytici | cas | grantAll vedci | userGroup | serviceAction | vedci | cas | grantAll vedci | trustAnchor | serviceAction | KarolovaTA | cas | grantAll superUserGroup | user | serviceAction | karol | cas | grantAll superUserGroup | object | serviceAction | 4 | cas | grantAll superUserGroup | objectGroup | serviceAction | data | cas | grantAll superUserGroup | serviceType | serviceAction | directory | cas | grantAll superUserGroup | object | serviceAction | 1 | cas | superuser analytici | objectGroup | serviceAction | data | directory | citanie superUserGroup | object | serviceAction | 1 | directory | citanie
Ak object_specification je cislo tak referuje na object_id tabulky object_table kde v stlpci object_name
je meno objektu ktore potrebujem zobrazit vo vypise miesto tohoto cisla. Ak v qwery miesto policy_table.object_specification
dam vnoreny select: (SELECT object_table.object_name FROM object_table WHERE object_table.object_id = policy_table.object_specification LIMIT 1)
tak sa mi mena tych objektov vo vypise zobrazia, ale ostatne riadky v stlpci object_specification su prazdne.
Cela qwery po pridani vnoreneho selectu:
SELECT policy_table.user_group_name, policy_table.object_spec_desc, policy_table.action_spec_desc, (SELECT object_table.object_name FROM object_table WHERE object_table.object_id = policy_table.object_specification LIMIT 1), service_type_action.service_type_name, service_type_action.action_name FROM policy_table LEFT JOIN service_type_action ON policy_table.action_specification = service_type_action.service_action_id;
user_group_name | object_spec_desc | action_spec_desc | ?column? | service_type_name | action_name -----------------+------------------+------------------+--------------------------+-------------------+------------- superUserGroup | user | serviceAction | | cas | grantAll analytici | userGroup | serviceAction | | cas | grantAll vedci | userGroup | serviceAction | | cas | grantAll vedci | trustAnchor | serviceAction | | cas | grantAll superUserGroup | user | serviceAction | | cas | grantAll superUserGroup | object | serviceAction | ftp://ulozisko.yweb.sk/* | cas | grantAll superUserGroup | objectGroup | serviceAction | | cas | grantAll superUserGroup | serviceType | serviceAction | | cas | grantAll superUserGroup | object | serviceAction | casServer | cas | superuser analytici | objectGroup | serviceAction | | directory | citanie superUserGroup | object | serviceAction | casServer | directory | citanie
Nevie mi niekto poradit ako formulovat qwery aby sa zobrazili mena aj mena objektov sucasne?
SELECT object_table.object_name FROM object_table WHERE object_table.object_id = policy_table.object_specification LIMIT 1dotaz záznam.
No to nie lebo su tam iba dva zaznamy cize na object_id = 1 a 4. Tu je tabulka object_table:
object_id | object_name | namespace_nickname -----------+--------------------------+-------------------- 1 | casServer | casNamespace 4 | ftp://ulozisko.yweb.sk/* | FTPDirectoryTree
SELECT policy_table.user_group_name, policy_table.object_spec_desc, policy_table.action_spec_desc, object_table.object_name, (SELECT object_table.object_name FROM object_table WHERE (object_table.object_id = policy_table.object_specification or object_table.object_name = policy_table.object_specification) LIMIT 1), service_type_action.service_type_name, service_type_action.action_name FROM policy_table LEFT JOIN service_type_action ON policy_table.action_specification = service_type_action.service_action_id;Případně tam dej druhý join s object_table (takže ve výsledku bude join 3 tabulek).
TO nie vyhoti my to chybu:
CHYBA: chýbajúci záznam v klauzuli FROM pre tabulku "object_table"
Pouzi Case
Case
When (SELECT object_table.object_name FROM object_table WHERE object_table.object_id = policy_table.object_specification LIMIT 1) = Null Then policy_table.object_specification
Else (SELECT object_table.object_name FROM object_table WHERE object_table.object_id = policy_table.object_specification LIMIT 1)
End Case
Neviem ci je spravny syntax. Ja pisem hlavne v TSQL
Popripade urob ten join a vysledok urob z obidvoch stlpcov cez case alebo isnull (ma mysql isnull?)
Super, takto som to upravil a ide to:
SELECT policy_table.user_group_name, policy_table.object_spec_desc, policy_table.action_spec_desc, CASE WHEN (SELECT object_table.object_name FROM object_table WHERE object_table.object_id = policy_table.object_specification LIMIT 1) IS NULL THEN policy_table.object_specification ELSE (SELECT object_table.object_name FROM object_table WHERE object_table.object_id = policy_table.object_specification LIMIT 1) END, service_type_action.service_type_name, service_type_action.action_name FROM policy_table LEFT JOIN service_type_action ON policy_table.action_specification = service_type_action.service_action_id;
Dakujem Vsetkym za pomoc, hlavne pSipi.
object_table
).NVL()
, v MySQL se jmenuje IFNULL(sloupeček1, sloupeček2)
– pokud je sloupeček1
NULL, nahradí se hodnotou sloupeček2
. Místo sloupeček2
může být i vnořený dotaz:
IFNULL(sloupeček1, (SELECT 'ahoj')Jenže tady narážíš na prasáckost toho modelu – alespoň malé zlepšení by bylo, mít tam místo jednoho sloupečku dva – pokud je ten jeden nulový (NULL), dohledáš si pomocí
ifnull
druhého sloupečku a vnořeného dotazu tu správnou hodnotu (pak se ten vnořený select pustí, jen když je potřeba).
Tiskni
Sdílej: