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

    Rocky Linux byl vydán v nové stabilní verzi 9.4. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    včera 22:22 | Bezpečnostní upozornění

    Dellu byla odcizena databáze zákazníků (jméno, adresa, seznam zakoupených produktů) [Customer Care, Bleeping Computer].

    Ladislav Hagara | Komentářů: 4
    včera 21:11 | Zajímavý článek

    V lednu byl otevřen editor kódů Zed od autorů editoru Atom a Tree-sitter. Tenkrát běžel pouze na macOS. Byl napevno svázán s Metalem. Situace se ale postupně mění. V aktuálním příspěvku Kdy Zed na Linuxu? na blogu Zedu vývojáři popisují aktuální stav. Blíží se alfa verze.

    Ladislav Hagara | Komentářů: 12
    včera 14:33 | Pozvánky

    O víkendu 11. a 12. května lze navštívit Maker Faire Prague, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.

    Ladislav Hagara | Komentářů: 0
    8.5. 21:55 | Nová verze

    Byl vydán Fedora Asahi Remix 40, tj. linuxová distribuce pro Apple Silicon vycházející z Fedora Linuxu 40.

    Ladislav Hagara | Komentářů: 27
    8.5. 20:22 | IT novinky

    Představena byla služba Raspberry Pi Connect usnadňující vzdálený grafický přístup k vašim Raspberry Pi z webového prohlížeče. Odkudkoli. Zdarma. Zatím v beta verzi. Detaily v dokumentaci.

    Ladislav Hagara | Komentářů: 6
    8.5. 12:55 | Nová verze

    Byla vydána verze R14.1.2 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.

    JZD | Komentářů: 1
    7.5. 18:55 | IT novinky

    Dnešním dnem lze již také v Česku nakupovat na Google Store (telefony a sluchátka Google Pixel).

    Ladislav Hagara | Komentářů: 10
    7.5. 18:33 | IT novinky

    Apple představil (keynote) iPad Pro s čipem Apple M4, předělaný iPad Air ve dvou velikostech a nový Apple Pencil Pro.

    Ladislav Hagara | Komentářů: 4
    7.5. 17:11 | Nová verze

    Richard Biener oznámil vydání verze 14.1 (14.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 14. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (63%)
     (8%)
     (13%)
     (16%)
    Celkem 148 hlasů
     Komentářů: 10, poslední 8.5. 17:35
    Rozcestník

    Dotaz: Navrh db - mysql

    10.11.2008 22:49 xts | skóre: 10
    Navrh db - mysql
    Přečteno: 407×
    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.