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 03:33 | IT novinky

    Do prodeje jde tichá bezdrátová herní myš Logitech PRO X2 SUPERSTRIKE s analogovými spínači s haptickou odezvou (HITS, Haptic Inductive Trigger System). Cena je 4 459 Kč.

    Ladislav Hagara | Komentářů: 3
    včera 21:00 | Zajímavý projekt

    Microsoft na GitHubu zveřejnil zdrojový kód projektu LiteBox, jedná se o 'knihovní operační systém' (library OS) zaměřený na bezpečnost, využívající systémovou architekturu LVBS k ochraně jádra před útoky z uživatelského prostoru. LiteBox je napsán v Rustu a uvolněný pod licencí MIT. Projekt je teprve v rané fázi vývoje.

    NUKE GAZA! 🎆 | Komentářů: 1
    včera 16:11 | Zajímavý software

    BreezyBox je open-source shell a virtuální terminál pro populární jednočip ESP32. Nabízí základní unixové příkazy, sledování aktuálního pracovního adresáře (CWD), jednoduchý instalátor a spouštěč aplikací v podobě ELF binárních souborů, zabudovaný HTTP server nebo třeba ovládání WiFi - ukázka použití coby 'malého osobního počítače'. Ačkoliv je BreezyBox inspirovaný BusyBoxem, oproti němu má tento projekt několik externích závislostí, zejména na ESP-IDF SDK. BreezyBox je dostupný pod licencí MIT.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 16:00 | Humor

    Byl představen cross-assembler xa.sh, napsaný čistě v Bourne shell skriptu. Tento nástroj umožňuje zpracovávat assemblerový kód pro Intel 8080, přičemž je možné snadno přidat podporu i pro další architektury, například 6502 a 6809. Skript využívá pouze různé běžné unixové příkazy jako jsou awk, sed nebo printf. Skript si lze stáhnout z GitHubového repozitáře projektu.

    NUKE GAZA! 🎆 | Komentářů: 5
    6.2. 17:22 | IT novinky

    Byla představena nová verze modelu Claude Opus 4.6 od společnosti Anthropic. Jako demonstraci možností Anthropic využil 16 agentů Claude Opus 4.6 k vytvoření kompilátoru jazyka C, napsaného v programovacím jazyce Rust. Claude pracoval téměř autonomně, projekt trval zhruba dva týdny a náklady činily přibližně 20 000 dolarů. Výsledkem je fungující kompilátor o 100 000 řádcích kódu, jehož zdrojový kód je volně dostupný na GitHubu pod licencí Creative Commons.

    NUKE GAZA! 🎆 | Komentářů: 18
    6.2. 16:44 | Komunita

    Kultovní britský seriál The IT Crowd (Ajťáci) oslavil dvacáté výročí svého prvního vysílání. Sitcom o dvou sociálně nemotorných pracovnících a jejich nadřízené zaujal diváky svým humorem a ikonickými hláškami. Seriál, který debutoval v roce 2006, si i po dvou dekádách udržuje silnou fanouškovskou základnu a pravidelně se objevuje v seznamech nejlepších komedií své doby. Nedávné zatčení autora seriálu Grahama Linehana za hatecrime však vyvolává otázku, jestli by tento sitcom v současné Velké Británii vůbec vznikl.

    NUKE GAZA! 🎆 | Komentářů: 10
    6.2. 13:33 | IT novinky

    Společnost JetBrains oznámila, že počínaje verzí 2026.1 budou IDE založená na IntelliJ ve výchozím nastavení používat Wayland.

    Ladislav Hagara | Komentářů: 4
    6.2. 11:22 | IT novinky

    Společnost SpaceX amerického miliardáře Elona Muska podala žádost o vypuštění jednoho milionu satelitů na oběžnou dráhu kolem Země, odkud by pomohly zajistit provoz umělé inteligence (AI) a zároveň šetřily pozemské zdroje. Zatím se ale neví, kdy by se tak mělo stát. V žádosti Federální komisi pro spoje (FCC) se píše, že orbitální datová centra jsou nejúspornějším a energeticky nejúčinnějším způsobem, jak uspokojit rostoucí poptávku po

    … více »
    Ladislav Hagara | Komentářů: 27
    6.2. 11:11 | Nová verze

    Byla vydána nová verze 2.53.0 distribuovaného systému správy verzí Git. Přispělo 70 vývojářů, z toho 21 nových. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    6.2. 04:22 | Komunita

    Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 216. sraz, který proběhne v pátek 20. února od 18:00 v Red Hat Labu (místnost Q304) na Fakultě informačních technologií VUT v Brně na ulici Božetěchova 1/2. Tématem srazu bude komunitní komunikační síť MeshCore. Jindřich Skácel představí, co je to MeshCore, předvede nejrůznější klientské zařízení a ukáže, jak v praxi vypadá nasazení vlastního repeateru.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (10%)
     (26%)
     (3%)
     (4%)
     (2%)
     (12%)
     (29%)
    Celkem 805 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: Propojeni 2 tabulek v PHP

    24.10.2008 20:03 Tomyx007
    Propojeni 2 tabulek v PHP
    Přečteno: 602×
    Prosim o radu, jak jednoduse propojit v PHP dve tabulky "polls" (se sloupci: ID_pollu,ID_Candidate1, ID_Candidate2, ID_Candidate3, ID_Candidate4,Votes1,Votes2,Votes3,Votes4) a tabulku "candidates" (se sloupci:ID, Prijmeni). Kde vzdy kazdemu ID_Candidate (v tabulce "polls") odpovida jedno ID (v tabulce "candidates"). Cilem je vypsat prijmeni kandidatu (z tabulky "candidates") a jim odpovidajici hlasy (Votes z tabulky "polls"). Ted jsem to resil slozitym zpusobem: $vysledek=mysql_query("SELECT * FROM polls where id='$idpoll'"); $zaznam=mysql_fetch_array($vysledek);

    $vysledek2=mysql_query("SELECT * FROM candidates where id='".$zaznam['ID_Candidate1']."'"); $zaznam2=mysql_fetch_array($vysledek2); $data['0']['prijmeni'] = $zaznam2['Prijmeni'];

    $vysledek3=mysql_query("SELECT * FROM candidates where id='".$zaznam['ID_Candidate2']."'"); $zaznam3=mysql_fetch_array($vysledek3); $data['1']['prijmeni'] = $zaznam3['Prijmeni'];

    $vysledek4=mysql_query("SELECT * FROM candidates where id='".$zaznam['ID_Candidate3']."'"); $zaznam4=mysql_fetch_array($vysledek4); $data['2']['prijmeni'] = $zaznam4['Prijmeni'];

    Odpovědi

    24.10.2008 21:24 Petr Svoboda | skóre: 13 | blog: * | Příbram
    Rozbalit Rozbalit vše Re: Propojeni 2 tabulek v PHP
    Nebudu zabíhat do zbytečných detailů. Zkusil bych cosi jako
    SELECT * FROM polls p, candidates c1, candidates c2
    WHERE p.ID = $idpoll AND p.ID_Candidate1 = c1.ID AND p.ID_Candidate2 = c2.ID
    
    S dovolením jsem vynechal 3. a 4. kandidáta, ale jak je přidat je snad zřejmé.

    Nicméně bych se spíš zkusil zamyslet nad změnou schématu (pokud je to možné). Asi bych zvolil něco jako:
    • polls(id)
    • votes(id, id_poll, id_candidate, votes)
    • candidates(id, name)
    Je to výrazně flexibilnější, na druhou stranu budou složitější inserty.

    Select by pak mohl být nějak takto:
    SELECT * FROM votes v, candidates c
    WHERE v.id_poll = $idpoll AND v.id_candidate = c.id
    
    26.10.2008 11:50 Tomyx007
    Rozbalit Rozbalit vše Re: Propojeni 2 tabulek v PHP
    Dekuji za odpoved - fungule to. Slo by jetse nejak resit, pokud ma v tabulce "polls" nektery napr. sloupec ID_Candidate3 hodnotu 0 (stejne tak sloupec Votes3 ma 0), tak dotaz nevypise zadny zaznam, kdyz se zmeni podminka z AND na OR, tak se jich vypise zase mnoho, slo by toto nejka resit?
    default avatar 26.10.2008 14:53 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: Propojeni 2 tabulek v PHP
    Příloha:
    Předpokládám, že hodnotou nula (0) řešíš nepovinnou vazbu. Od toho je NULL a naštěstí to jde velice jednoduše opravit ;-) Předpokládám testovací data z přílohy. Předtím, než nahodíme referenční integritu, musíme data pročistit.

    Před vlastní modifikací jen povolíme NULL hodnoty:
    ALTER TABLE polls MODIFY id_candidate1 NULL
    /
    
    ALTER TABLE polls MODIFY id_candidate2 NULL
    /
    
    ALTER TABLE polls MODIFY id_candidate3 NULL
    /
    
    ALTER TABLE polls MODIFY id_candidate4 NULL
    /
    Pak nastavíme neplatné klíče na NULL:
    UPDATE polls p
    SET
        p.id_candidate1 = NULL
    WHERE
        NOT EXISTS (SELECT
                1
            FROM
                candidates cc
            WHERE
                cc.id = p.id_candidate1)
    /
    
    UPDATE polls p
    SET
        p.id_candidate2 = NULL
    WHERE
        NOT EXISTS (SELECT
                1
            FROM
                candidates cc
            WHERE
                cc.id = p.id_candidate2)
    /
    
    UPDATE polls p
    SET
        p.id_candidate3 = NULL
    WHERE
        NOT EXISTS (SELECT
                1
            FROM
                candidates cc
            WHERE
                cc.id = p.id_candidate3)
    /
    
    UPDATE polls p
    SET
        p.id_candidate4 = NULL
    WHERE
        NOT EXISTS (SELECT
                1
            FROM
                candidates cc
            WHERE
                cc.id = p.id_candidate4)
    /
    
    COMMIT
    /
    Poté nahoíme referenční integritu:
    ALTER TABLE candidates ADD CONSTRAINT pk_candidates PRIMARY KEY (id)
    /
    
    ALTER TABLE polls ADD CONSTRAINT fk_vote_candidate1 FOREIGN KEY (id_candidate1) REFERENCES candidates (id)
    /
    
    ALTER TABLE polls ADD CONSTRAINT fk_vote_candidate2 FOREIGN KEY (id_candidate2) REFERENCES candidates (id)
    /
    
    ALTER TABLE polls ADD CONSTRAINT fk_vote_candidate3 FOREIGN KEY (id_candidate3) REFERENCES candidates (id)
    /
    
    ALTER TABLE polls ADD CONSTRAINT fk_vote_candidate4 FOREIGN KEY (id_candidate4) REFERENCES candidates (id)
    /
    Každopádně: ve všech případech funguje tento SELECT statement:
    SELECT
        c1.prijmeni AS candidate1_surname,
        p.votes1 AS candidate1_votes,
        c2.prijmeni AS candidate2_surname,
        p.votes2 AS candidate2_votes,
        c3.prijmeni AS candidate3_surname,
        p.votes3 AS candidate3_votes,
        c4.prijmeni AS candidate4_surname,
        p.votes4 AS candidate4_votes
    FROM
        polls p
            LEFT JOIN candidates c1 ON (p.id_candidate1 = c1.id)
            LEFT JOIN candidates c2 ON (p.id_candidate2 = c2.id)
            LEFT JOIN candidates c3 ON (p.id_candidate3 = c3.id)
            LEFT JOIN candidates c4 ON (p.id_candidate4 = c4.id)
    /
    Tak hodně štěstí. (V příloze máš kompletní skript na hraní.)
    26.10.2008 20:34 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Propojeni 2 tabulek v PHP
    k joinom ... teda neviem ako mysql, ale nechýba ti tam outer ?
    default avatar 26.10.2008 20:46 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: Propojeni 2 tabulek v PHP
    LEFT OUTER JOIN a LEFT JOIN jsou ekvivalentní. Klíčové slovo OUTER je nepovinné, protože LEFT nebo RIGHT JOIN je vždy "OUTER".
    default avatar 26.10.2008 14:24 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: Propojeni 2 tabulek v PHP
    A co takhle?
    SELECT
        c1.prijmeni AS candidate1_surname,
        p.votes1 AS candidate1_votes,
        c2.prijmeni AS candidate2_surname,
        p.votes2 AS candidate2_votes,
        c3.prijmeni AS candidate3_surname,
        p.votes3 AS candidate3_votes,
        c4.prijmeni AS candidate4_surname,
        p.votes4 AS candidate4_votes
    FROM
        polls p
            LEFT JOIN candidates c1 ON (p.id_candidate1 = c1.id)
            LEFT JOIN candidates c2 ON (p.id_candidate2 = c2.id)
            LEFT JOIN candidates c3 ON (p.id_candidate3 = c3.id)
            LEFT JOIN candidates c4 ON (p.id_candidate4 = c4.id)
    /
    

    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.