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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

Ladislav Hagara | Komentářů: 0
dnes 00:10 | Nová verze

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

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

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 16
včera 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 2
5.12. 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 6
5.12. 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 50
5.12. 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 10
3.12. 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 17
3.12. 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
2.12. 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 26
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (8%)
 (5%)
 (3%)
Celkem 780 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: Propojeni 2 tabulek v PHP

24.10.2008 20:03 Tomyx007
Propojeni 2 tabulek v PHP
Přečteno: 495×
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.