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í
×
    včera 07:33 | Komunita

    O víkendu probíhá konference OpenAlt 2025 (Stream). Na programu je spousta zajímavých přednášek. Pokud jste v Brně, stavte se. Vstup zdarma.

    Ladislav Hagara | Komentářů: 0
    včera 00:55 | IT novinky

    Josef Průša představil novou velkoformátovou uzavřenou CoreXY 3D tiskárnu Prusa CORE One L a nový open source standard chytrých cívek OpenPrintTag i s novou přepracovanou špulkou.

    Ladislav Hagara | Komentářů: 7
    31.10. 18:33 | IT novinky

    Na GOG.com běží Autumn Sale. Při té příležitosti je zdarma hororová počítačová hra STASIS (ProtonDB: Platinum).

    Ladislav Hagara | Komentářů: 0
    31.10. 13:22 | Komunita

    Ubuntu 25.10 má nově balíčky sestavené také pro úroveň mikroarchitektury x86-64-v3 (amd64v3).

    Ladislav Hagara | Komentářů: 8
    31.10. 01:22 | Nová verze

    Byla vydána verze 1.91.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
    31.10. 00:11 | IT novinky

    Ministerstvo průmyslu a obchodu vyhlásilo druhou veřejnou soutěž v programu TWIST, který podporuje výzkum, vývoj a využití umělé inteligence v podnikání. Firmy mohou získat až 30 milionů korun na jeden projekt zaměřený na nové produkty či inovaci podnikových procesů. Návrhy projektů lze podávat od 31. října do 17. prosince 2025. Celková alokace výzvy činí 800 milionů korun.

    Ladislav Hagara | Komentářů: 5
    30.10. 23:44 | Komunita

    Google v srpnu oznámil, že na „certifikovaných“ zařízeních s Androidem omezí instalaci aplikací (včetně „sideloadingu“) tak, že bude vyžadovat, aby aplikace byly podepsány centrálně registrovanými vývojáři s ověřenou identitou. Iniciativa Keep Android Open se to snaží zvrátit. Podepsat lze otevřený dopis adresovaný Googlu nebo petici na Change.org.

    Ladislav Hagara | Komentářů: 0
    30.10. 15:22 | Nová verze

    Byla vydána nová verze 18 integrovaného vývojového prostředí (IDE) Qt Creator. S podporou Development Containers. Podrobný přehled novinek v changelogu.

    Ladislav Hagara | Komentářů: 2
    30.10. 12:55 | Nová verze

    Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 2.0. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).

    Ladislav Hagara | Komentářů: 1
    30.10. 02:55 | Nová verze

    Google Chrome 142 byl prohlášen za stabilní. Nejnovější stabilní verze 142.0.7444.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 20 bezpečnostních chyb. Za nejvážnější z nich bylo vyplaceno 50 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (19%)
     (18%)
     (22%)
     (16%)
     (20%)
     (16%)
     (17%)
    Celkem 298 hlasů
     Komentářů: 15, poslední dnes 08:25
    Rozcestník

    Dotaz: Navrh db - mysql

    10.11.2008 22:49 xts | skóre: 10
    Navrh db - mysql
    Přečteno: 431×
    Zdravim,

    zprovoznuju databazi pod mysql ze ktere si bude php tahat data. Bude se jednat o firmy a jejich kontakty. Tech firem bude vic, tech kontaktu hodne, tj. stovky, tisice, mozna vic. Jaky by byl optimalni navrh databaze? Kdyz vytvorim tabulku treba "firmy" a kazda bude mit jeden radek, nepridam tam neomezene kontaktu. Vytvaret tabulku pro kazdou firmu mi prijde divny, je to ok nebo ne? Vpodstate jediny reseni ktery me napadlo je jedna tabulka "firmy" kde kazda bude mit svoje id, a tabulka "kontakty" kde budou vsechny kontakty dohromady a u nich id ke komu patri. Je to cisty? Jak byste to resili vy co se v tom vyznate?

    A jeste jeden hloupej dotaz - sql predpokladam ma limit jenom vykonovej, tzn. kdyz tech kontaktu v jedny tabulce bude treba 100000 nebo i vic bude to ok?

    diky

    Odpovědi

    10.11.2008 23:23 mozog | skóre: 28
    Rozbalit Rozbalit vše Re: Navrh db - mysql
    Ahoj,

    ja podobne veci riesim tak, ako si popisal v druhej casti - zoznam firiem v jednej tabulke, kde je ID firmy, meno firmy a dalsie dolezite udaje, a druha tabulka, kde je tiez ID firmy, jednotlive kontakty, prip. dalsie potrebne udaje.
    Zase na druhu stranu, ak by pocet firiem bol relativne maly, tak mozes urobit samostatne tabulky s kontaktmi pre kazdu firmu.
    11.11.2008 13:26 xts | skóre: 10
    Rozbalit Rozbalit vše Re: Navrh db - mysql
    diky vsem za pomoc.
    Heron avatar 11.11.2008 07:48 Heron | skóre: 53 | blog: root_at_heron | Olomouc
    Rozbalit Rozbalit vše Re: Navrh db - mysql
    Toto je klasický příklad N:M relace. Jedna firma má mnoho kontatků s jeden kontakt patří mnoha firmám.

    V zásadě se to řeší třemi tabulkami. Tabulka Firmy (ID_FIRMA, JMENO_F, ....) Tabulka Kontakty (ID_KONTAKT, JMENO_K,...) a spojovaci tabulka relace N:M (ID_FIRMY, ID_KONTAKTU). Pokud pak chcete k nějaké firmě vytáhnout všechny kontakty, tak je to SELECT podle ID_FIRMY a JOIN s tabukou kontaktů (pro vytažení třeba jména a telefonu).
    11.11.2008 18:31 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Navrh db - mysql
    Pokud pak chcete k nějaké firmě vytáhnout všechny kontakty
    Ona ale může nastat i opačná situace, a to pak potrápí. Jsem rád, že už jsem to dlouho nemusel řešit, ale kdybych musel někdy rozhodovat o vazbě firma-kontakt nebo firma-adresa, dlouho bych se rozmýšlel, jestli ji radši neudělat 1:N.
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    Heron avatar 11.11.2008 19:05 Heron | skóre: 53 | blog: root_at_heron | Olomouc
    Rozbalit Rozbalit vše Re: Navrh db - mysql
    Opačná situace je která? Jestli ke kontaktu najít všechny firmy, tak to jde uplně stejným způsobem (akorát se v tom dotazu změní jména tabulek). Takto rozložená vazba N:M je z obou stran stejná.
    11.11.2008 19:24 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Navrh db - mysql
    Opačná situace je najít, ke které firmě kontakt patří.

    Uvědomuju si, že taková potřeba vyvstává v podstatě kvůli nedostatku v návrhu (no, dalo by se diskutovat, zda je nedostatek neuložit si vedle kontaktu taky o jakou firmu jde, protože to komplikuje uživatelské rozhraní), ale ona kupodivu vyvstává…
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    Heron avatar 11.11.2008 19:29 Heron | skóre: 53 | blog: root_at_heron | Olomouc
    Rozbalit Rozbalit vše Re: Navrh db - mysql
    Buď si nerozumíne, nebo oba mluvíme o něčem jiném. V příkladu, který jsem ukázal prve, je stejně jednoduché k firmě najít kontakty, jako najít ke kontaktu firmy.
    11.11.2008 20:24 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Navrh db - mysql
    To samozřejmě ano, ale já úmyslně mluvím v jednotném čísle :-) Ono už je to tady offtopic, ale když máte z nějaké tabulky vazbu na kontakt, ale už ne na firmu, zažijete perné chvíle, když po pár letech přijde požadavek na sestavu, ve které budete chtít sčítat přes firmy. Ale jak říkám, to je OT, tak to asi nechme.
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    Heron avatar 11.11.2008 20:26 Heron | skóre: 53 | blog: root_at_heron | Olomouc
    Rozbalit Rozbalit vše Re: Navrh db - mysql
    Tak takhle samozřejmě ano :-). Ale i toto se dá řešit jinak, než uměle vytvořenou vazbou 1:N. Pravda, je to OT.
    Heron avatar 11.11.2008 07:52 Heron | skóre: 53 | blog: root_at_heron | Olomouc
    Rozbalit Rozbalit vše Re: Navrh db - mysql
    K tomu výkonu. U DB výkon prakticky nezáleží na počtu záznamů. Vše závisí na návrhu DB schematu (normální formy, sloupce jsou malé a mají vhodné datové typy) a na optimalizaci dotazů (vybírám jen to co potřebuju, vše nad čím vyhledávám a spojuji má vhodné indexy atd).
    11.11.2008 11:08 Tomas
    Rozbalit Rozbalit vše Re: Navrh db - mysql

    Zkuste si přečíst něco od E-R modelování. Třeba tady, tady a tady. To by Vás mělo nasměrovat správným směrem.

    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.