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 04:10 | Nová verze

Po 10 týdnech vývoje od vydání Linuxu 4.9 (zprávička) oznámil Linus Torvalds, mj. již 20 let žijící v USA, vydání Linuxu 4.10 (LKML). Přehled nových vlastností a vylepšení například na Kernel Newbies a v Jaderných novinách (1, 2 a 3). Kódové jméno Linuxu 4.10 je Fearless Coyote.

Ladislav Hagara | Komentářů: 1
včera 15:55 | Zajímavý projekt

Vyzkoušet si příkazy a vyřešit několik úkolů lze na stránkách Commandline Challenge (CMD Challenge). Úkoly lze řešit různými způsoby, důležitý je výsledek. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.

Ladislav Hagara | Komentářů: 10
18.2. 17:35 | Bezpečnostní upozornění

Německá Bundesnetzagentur (obdoba českého ČTU) zakázala na německém území prodej panenky Cayla kvůli „špionáži“ dětí. Tato elektronická hračka obsahuje mikrofon, reproduktor a kameru a bezdrátové komunikační rozhraní, pomocí kterého se hračka připojuje na servery výrobce. Takovýmto způsobem může hračka pomocí umělé inteligence „odpovídat“ na dotazy dítěte. Hlavní problém bude ale asi někde jinde, podle prvotních zpráv může

… více »
Petr Tomášek | Komentářů: 27
17.2. 15:30 | Bezpečnostní upozornění

CSIRT.CZ upozorňuje, že bezpečnostní experti objevili nový typ malwaru, jenž cílí na open source e-commerce platformu Magento. Malware je zajímavý tím, že se jedná o první svého druhu, jehož kód zůstává skrytý v SQL databázi zasaženého e-shopu. Škodlivý kód je volán pomocí tzv. SQL trigerru, který je spouštěn při každém vytvoření objednávky v systému.

Ladislav Hagara | Komentářů: 2
17.2. 09:00 | Nová verze

Bylo vydáno Ubuntu 16.04.2 LTS, tj. druhé opravné vydání Ubuntu 16.04 LTS s kódovým názvem Xenial Xerus. Přehled novinek v poznámkách k vydání a v přehledu změn.

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

Pavel Tišnovský se v dvoudílném článku na MojeFedora.cz věnuje tvorbě pluginů (modulů) pro bitmapový grafický editor GIMP. Pomocí pluginů lze GIMP rozšiřovat o další funkce. Implementovat lze například nové filtry nebo pomocné utility pro tvorbu animací či poloautomatickou retuš snímků.

Ladislav Hagara | Komentářů: 6
16.2. 23:32 | Komunita

Do 30. března se lze přihlásit do dalšího kola programu Outreachy, jehož cílem je přitáhnout do světa svobodného a otevřeného softwaru lidi ze skupin, jež jsou ve světě svobodného a otevřeného softwaru málo zastoupeny. Za 3 měsíce práce, od 30. května do 30. srpna 2017, v participujících organizacích lze vydělat 5 500 USD. Jedná se již o 14. kolo tohoto programu.

Ladislav Hagara | Komentářů: 11
16.2. 23:13 | Nová verze

Byla vydána verze 0.92.1 svobodného multiplatformního vektorového grafického editoru Inkscape. Přehled novinek v poznámkách k vydání. Řešen je mimo jiné problém s verzí 0.92, jež rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Více v příspěvku na blogu Davida Revoye, autora open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu.

Ladislav Hagara | Komentářů: 0
16.2. 16:26 | Bezpečnostní upozornění

Byla vydána verze 1.1.0e kryptografické knihovny OpenSSL. Dle bezpečnostního upozornění 20170216 byla opravena závažná bezpečnostní chyba CVE-2017-3733.

Ladislav Hagara | Komentářů: 1
16.2. 13:03 | Pozvánky

GNOME hackaton proběhne v Brně na FIT VUT v Red Hat Labu (budova Q) v pondělí 20. února od 15:00. Registrace není nutná, ale pokud dáte na FaceBooku vědět, že plánujete dorazit, pomůže to s plánováním.

Ladislav Hagara | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (13%)
 (2%)
 (72%)
 (3%)
 (10%)
Celkem 660 hlasů
 Komentářů: 52, poslední 13.2. 12:45
Rozcestník
Reklama

Dotaz: Propojeni 2 tabulek v PHP

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