abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 17:33 | Nová verze

    Byla vydána nová stabilní verze 7.6 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 140. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    dnes 16:22 | Nová verze

    Byla vydána verze 1.90.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    dnes 16:11 | Nová verze

    GNUnet (Wikipedie) byl vydán v nové major verzi 0.25.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.

    Ladislav Hagara | Komentářů: 0
    dnes 12:11 | Nová verze

    Byla vydána nová major verze 7.0 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Nově je postavena je na Debianu 13 (Trixie) a GNOME 48 (Bengaluru). Další novinky v příslušném seznamu.

    Ladislav Hagara | Komentářů: 0
    dnes 04:44 | IT novinky

    Společnost Meta na dvoudenní konferenci Meta Connect 2025 představuje své novinky. První den byly představeny nové AI brýle: Ray-Ban Meta (Gen 2), sportovní Oakley Meta Vanguard a především Meta Ray-Ban Display s integrovaným displejem a EMG náramkem pro ovládání.

    Ladislav Hagara | Komentářů: 0
    dnes 01:11 | Nová verze

    Po půl roce vývoje od vydání verze 48 bylo vydáno GNOME 49 s kódovým názvem Brescia (Mastodon). S přehrávačem videí Showtime místo Totemu a prohlížečem dokumentů Papers místo Evince. Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.

    Ladislav Hagara | Komentářů: 11
    včera 16:22 | Nová verze

    Open source softwarový stack ROCm (Wikipedie) pro vývoj AI a HPC na GPU od AMD byl vydán ve verzi 7.0.0. Přidána byla podpora AMD Instinct MI355X a MI350X.

    Ladislav Hagara | Komentářů: 0
    včera 15:22 | Nová verze

    Byla vydána nová verze 258 správce systému a služeb systemd (GitHub).

    Ladislav Hagara | Komentářů: 6
    včera 15:11 | Nová verze

    Byla vydána Java 25 / JDK 25. Nových vlastností (JEP - JDK Enhancement Proposal) je 18. Jedná se o LTS verzi.

    Ladislav Hagara | Komentářů: 0
    včera 14:44 | Humor

    Věra Pohlová před 26 lety: „Tyhle aféry každého jenom otravují. Já bych všechny ty internety a počítače zakázala“. Jde o odpověď na anketní otázku deníku Metro vydaného 17. září 1999 na téma zneužití údajů o sporožirových účtech klientů České spořitelny.

    Ladislav Hagara | Komentářů: 9
    Jaké řešení používáte k vývoji / práci?
     (41%)
     (56%)
     (3%)
     (9%)
     (13%)
     (6%)
     (13%)
     (6%)
     (16%)
    Celkem 32 hlasů
     Komentářů: 4, poslední dnes 19:18
    Rozcestník

    Dotaz: Jak spojit vše ze dvou tabulek

    20.4.2013 11:25 Dan
    Jak spojit vše ze dvou tabulek
    Přečteno: 892×
    Zdravím, mám dvě tabulky (user_log a log) a chtěl bych je vypsat do jedné tabulky, ale když jsem zkoušel:
    SELECT * FROM user_log UNION ALL log
    
    Tak my to vyhodí vyjímku The used SELECT statements have a different number of columns Já bych ale potřeboval všechny data z obou tabulek a nad nimi udělat WHERE created > '2013-02-02' user_log má 10 sloupcá a log jen 5, takže bych pak ve výpisu prostě nechal prázdné místo když tam ta hodnota nění. Jak něco takového udělat?

    Řešení dotazu:


    Odpovědi

    20.4.2013 11:56 rastos | skóre: 63 | blog: rastos
    Rozbalit Rozbalit vše Re: Jak spojit vše ze dvou tabulek
    outer join ?

    Môžeš sem dať štruktúru tých tabuliek?
    20.4.2013 14:20 jekub
    Rozbalit Rozbalit vše Re: Jak spojit vše ze dvou tabulek
    Pokud ty tabulky nesouvisí, tak je chcete sjednotit. To samozrejme je možné. Např.
    select * from(
    select 'user_log',col1,col2,null from user_log
    union all
    select 'log',col1,null,col2 from log
    ) where col1=42
    
    Pokud je chcete spojit, použijete join (inner, left, right, full, cross)
    Řešení 1× (jekub)
    21.4.2013 22:36 Logik
    Rozbalit Rozbalit vše Re: Jak spojit vše ze dvou tabulek
    Nevím, jestli Ti to je z předchozích odpovědí jasný, ale pokud jak předpokládám chceš ty tabulky pod sebou, tak z jedné musíš udělat takový select, aby datový typy odpovídaly datovým typům v druhé tabulce. Pokud tabulce log odpovídá prvních pět sloupců v user_log, jde to takto:

    SELECT * FROM user_log UNION ALL SELECT log.*, null, null, null, null, null FROM log

    ...pokud jsou sloupce napřeskáčku, nezbyde Ti, než v druhém selectu sloupce postupně vyjmenovat a proložit null.

    V některých databázích je také třeba určit datový typ toho null sloupce, např. CAST(null as integer)

    Pak je ještě o něco čistší cesta: Vytvoř si nad log view (pomocí selectu výše) a pak udělej jednoduchej union na ten view.

    Ale pokud něco takového potřebuješ, zamyslel bych se, zdali ve skutečnosti není chyba v návrhu a neměla být původně tabulka log a log_user jedna dohromady.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.