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 17:00 | IT novinky

    Podvodné reklamy na sociálních internetových platformách, jako je Facebook, Instagram nebo X, vytvořily loni v Česku jejich provozovatelům příjmy 139 milionů eur, tedy zhruba 3,4 miliardy korun. Proti roku 2022 je to nárůst o 51 procent. Vyplývá to z analýzy Juniper Research pro společnost Revolut. Podle výzkumu je v Česku zhruba jedna ze sedmi zobrazených reklam podvodná. Je to o 14,5 procenta více, než je evropský průměr, kde je podvodná každá desátá reklama.

    Ladislav Hagara | Komentářů: 0
    dnes 15:44 | Nová verze

    Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.6 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.

    Ladislav Hagara | Komentářů: 0
    dnes 03:22 | Nová verze

    Czkawka a Krokiet, grafické aplikace pro hledání duplicitních a zbytečných souborů, byly vydány ve verzi 11.0. Podrobný přehled novinek v příspěvku na Medium. Od verze 7.0 je vedle frontendu Czkawka postaveného nad frameworkem GTK 4 vyvíjen nový frontend Krokiet postavený nad frameworkem Slint. Frontend Czkawka je už pouze v udržovacím módu. Novinky jsou implementovány ve frontendu Krokiet.

    Ladislav Hagara | Komentářů: 12
    dnes 02:00 | Zajímavý článek

    Jiří Eischmann na svém blogu publikoval článek Úvod do MeshCore: "Doteď mě radioamatérské vysílání úplně míjelo. Když jsem se ale dozvěděl, že existují komunity, které svépomocí budují bezdrátové sítě, které jsou nezávislé na Internetu a do značné míry taky elektrické síti a přes které můžete komunikovat s lidmi i na druhé straně republiky, zaujalo mě to. Když o tom přede mnou pořád básnili kolegové v práci, rozhodl jsem se, že to zkusím taky.

    … více »
    Ladislav Hagara | Komentářů: 1
    včera 22:55 | Nová verze

    Byla vydána verze 0.5.20 open source správce počítačových her na Linuxu Lutris (Wikipedie). Přehled novinek v oznámení na GitHubu. Instalovat lze také z Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 12:44 | IT novinky

    Peter Steinberger, autor open source AI asistenta OpenClaw, nastupuje do OpenAI. OpenClaw bude převeden pod nadaci a zůstane otevřený a nezávislý.

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

    Společnost Backblaze zveřejnila statistiky spolehlivosti pevných disků používaných ve svých datových centrech za rok 2025. Ke konci roku 2025 vlastnila 349 462 pevných disků. Průměrná AFR (Annualized Failure Rate), tj. pravděpodobnost, že disk během roku selže, byla 1,36 %. V roce 2024 to bylo 1,57 %. V roce 2023 to bylo 1,70 %. V roce 2022 to bylo 1,37 %.

    Ladislav Hagara | Komentářů: 13
    15.2. 21:55 | Zajímavý software

    Nástroj sql-tap je proxy mezi aplikací a databází, které zachytává všechny SQL dotazy a zobrazuje je v terminálovém rozhraní. Zde lze téměř v reálném čase zkoumat dotazy, sledovat transakce a spouštět SQL příkaz EXPLAIN. Podporované databázové systémy jsou pouze PostgreSQL a MySQL. Zdrojový kód je dostupný na GitHubu, pod licencí MIT.

    NUKE GAZA! 🎆 | Komentářů: 0
    15.2. 13:55 | Nová verze

    Byla vydána nová verze 9.2 textového editoru Vim (Vi IMproved). Přináší vylepšené doplňování, podporu schránky ve Waylandu, podporu XDG Base Directory (konfigurace v $HOME/.config/vim), vylepšené Vim9 skriptování nebo lepší zvýrazňování změn. Vim zůstává charityware. Nadále vybízí k podpoře dětí v Ugandě. Z důvodu úmrtí autora Vimu Brama Moolenaara a ukončení činnosti jím založené charitativní organizace ICCF Holland projekt Vim navázal spolupráci s charitativní organizaci Kuwasha.

    Ladislav Hagara | Komentářů: 4
    14.2. 12:33 | Zajímavý projekt

    Byl představen editor MonoSketch, webová aplikace pro tvorbu diagramů, technických nákresů, flowchartů a různých dalších vizualizací, to vše jenom z ASCII znaků. Všechny operace běží pouze v prohlížeči uživatele a neprobíhá tedy žádné nahrávání dat na server. Zdrojový kód aplikace (drtivá většina Kotlin, žádné C#) je dostupný na GitHubu pod licencí Apache 2.0.

    NUKE GAZA! 🎆 | Komentářů: 5
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (11%)
     (27%)
     (3%)
     (4%)
     (2%)
     (12%)
     (27%)
    Celkem 887 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    CakePHP: tvoríme CMS - 4 (Model)

    18. 6. 2008 | Tibor Piňo | Programování | 7296×

    V minulej časti seriálu sme si vysvetlili srdce frameworku Active Record. Od dnešnej časti sa pustíme do programovania nášho CMS a začneme návrhom databázy a vytvorením databázovej vrstvy našej aplikácie tzv. Modelu.

    1. Konvencie CakePHP

    link

    Aby sme vedeli správne navrhnúť databázu a CakePHP na jej základe správne chápal väzby medzi tabuľkami, je potrebné poznať konvencie pre návrh databázy. Čo myslíme tým, aby CakePHP správne chápal väzby medzi tabuľkami? Znamená to, že ak budeme mať databázu správne navrhnutú, framework bude automaticky rozpoznávať cudzie kľúče, primárne kľúče a väzby medzi tabuľkami a nebudeme ich musieť pre každú tabuľku explicitne zadávať.

    Ešte je dobré poznamenať, že je veľmi rozumné zadávať názvy tabuliek, modelov atď. v anglickom jazyku. CakePHP automaticky chápe anglické jednotné a množné čísla, takže sa vyhneme zbytočným nastavovaniam (samozrejme je možné zadávať názvy aj v národných jazykoch, ale je to práca naviac a my preto budeme používať anglické konvencie).

    Názvy tabuliek
    Názvy tabuliek sa zapisujú pomenovaním v množnom čísle jednotiek, ktoré uchovávajú. Napríklad máme tabuľku, ktorá uchováva články, preto musí byť táto tabuľka pomenovaná v množnom čísle, v našom prípade articles.
    Primárny kľúč
    Primárny kľúč sa v tabuľkách označuje pomenovaním id. Taktiež platí, že môžeme používať aj iné pomenovanie pre primárny kľúč, ale opäť to musíme explicitne nastaviť.
    Cudzie kľúče
    Cudzie kľúče sa v tabuľkách označujú podľa tabuľky, kde sa pôvodne nachádzajú. Predstavme si, že každý článok má svojho autora. Čiže budeme mať dve tabuľky a to articles a users. V tabuľke articles sa bude potom pochopiteľne nachádzať cudzí kľúč z tabuľky users a to pomenovaním user_id. Čiže nám je hneď zrejmé, že cudzí kľúč sa tvorí podľa konvencie jednotne_cislo_tabulky_cudzieho_kluca_id.
    Názvy atribútov
    Ešte spomeniem, že je celkom vhodné, aby sa atribút názov pomenovával ako name. Oceníme to najmä pri generovaní select boxov vo väzbách 1:N, kde si budeme chcieť napríklad pri článku zvoliť kategóriu výberom z niekoľkých možností. Samozrejme aj tu platí, že môžeme používať iné pomenovanie ako name, avšak opäť by sme sa neskôr nevyhli niektorým nastaveniam, ktoré, ak dodržiavame konvencie, nie je potrebné vykonávať.
    Spojovacia tabuľka pri väzbe N:M
    Tabuľky, ktoré sú vo väzbe N:M, abecedne zoradíme a následne novú tabuľku pomenujeme podľa konvencie nazov_prvej_tabulky_nazov_druhej_tabulky. Predstavme si, že náš článok má N nálepiek a jedna nálepka môže byť v M článkoch. Máme teda tabuľky pomenované articles a tags a následne vytvoríme spojovaciu tabuľku, ktorú pomenujeme articles_tags. Cudzie kľúče do spojovacej tabuľky vytvoríme podľa konvencií, ktoré sme si definovali vyššie, čiže article_id a tag_id.

    2. Navrhujeme databázu

    link

    Na obrázku môžeme vidieť našu databázu pre náš nový redakčný systém, ktorú sme navrhli na základe vyššie definovaných konvencií

    CakePHP: návrh databáze

    3. Modely tabuliek

    link

    Databázu už máme správne navrhnutú a môžeme sa pustiť do tej najzaujímavejšej časti, a to je návrh databázovej vrstvy našej aplikácie, tzv. Modelu, čo je jedna z troch častí návrhového vzoru Model View Controller. Ako sme si už spomínali v predchádzajúcej časti seriálu, modely sa umiestňujú do adresára app/models. V našom prípade vytvoríme 4 modely, i keď máme tabuliek spolu 5. Ako sme si už spomínali, model sa pre spojovaciu tabuľku nevytvára a kedže máme databázu správne navrhnutú, všetku potrebnú prácu v súvislosti so spojovacou tabuľkou vykoná Cake automaticky. Predtým, než začneme vytvárať samotné modely, treba poznamenať, že model sa pomenováva ako jednotné číslo názvu tabuľky, čiže napr. pre našu tabuľku articles sa bude model nazývať Article a bude umiestnený v súbore app/models/article.php

    Model Article umiestený v súbore /app/models/article.php:

    <?php
    class Article extends AppModel {
    
            var $name = 'Article';
            var $useTable = 'articles';
            var $validate = array(
                    'title' => VALID_NOT_EMPTY,
                    'text' => VALID_NOT_EMPTY,
                    'user_id' => array('numeric'),
                    'created' => array('date')
            );
    
            var $belongsTo = array('User');
            var $hasAndBelongsToMany = array('Tag');
            var $hasMany = array('Comment');
    }
    ?>

    Model User umiestnený v súbore /app/models/user.php:

    <?php
    class User extends AppModel {
    
            var $name = 'User';
            var $useTable = 'users';
            var $validate = array(
                    'username' => VALID_NOT_EMPTY,
                    'password' => VALID_NOT_EMPTY
            );
    
            var $hasMany = array('Article');
    
    }
    ?>

    Model Comment umiestnený v súbore /app/models/comment.php:

    <?php
    class Comment extends AppModel {
    
            var $name = 'Comment';
            var $useTable = 'comments';
            var $validate = array(
                    'title' => VALID_NOT_EMPTY,
                    'text' => VALID_NOT_EMPTY,
                    'username' => VALID_NOT_EMPTY,
                    'article_id' => array('numeric')
            );
    
            var $belongsTo = array('Article');
    
    }
    ?>

    Model Tag umiestnený v súbore /app/models/tag.php:

    <?php
    class Tag extends AppModel {
    
            var $name = 'Tag';
            var $useTable = 'tags';
            var $validate = array(
                    'name' => VALID_NOT_EMPTY,
                    'seo_link' => VALID_NOT_EMPTY
            );
    
            var $hasAndBelongsToMany = array('Article');
    
    }
    ?>

    Ako môžeme vidieť vyššie, v kóde sme už uviedli aj validačné kritéria, ktoré sme si priblížili už v predchádzajúcej časti seriálu (podrobne sa im budeme venovať v niektorej z nasledujúcich častí). Využívať ich však budeme až v časti nasledujúcej, v ktorej sa budeme venovať vytváraniu zvyšných dvoch častí architektúry MVC, a to Controller a View.

    Aby sme si mohli otestovať, či sme našu databázu skutočne navrhli správne, môžeme využiť tzv. scaffolding. Cake nám pomocou scaffolding dokáže na základe vytvorených modelov automaticky skonštruovať ukážkovú aplikáciu, pomocou ktorej môžeme otestovať, či nám väzby v našej tabuľke fungujú správne. Potrebujeme však ku každému modelu vytvoriť Controller, aby sme mohli určiť, že Cake má používať na vytvorenie aplikácie scaffolding (ako som už spomínal vyššie, controlleru sa budeme venovať v nasledujúcej časti, preto nám teraz stačí bez hlbšieho vysvetlenie skopírovať jednotlivé kódy do konkrétnych súborov s controllermi).

    Controller Articles umiestnený v súbore /app/controllers/articles_controller.php:

    <?php
    class ArticlesController extends AppController {
    
            var $name = 'Articles';
            var $scaffold;
    }
    ?>

    Controller Users umiestnený v súbore /app/controllers/users_controller.php:

    <?php
    class UsersController extends AppController {
    
            var $name = 'Users';
            var $scaffold;
    }
    ?>

    Controller Comments umiestnený v súbore /app/controllers/comments_controller.php:

    <?php
    class CommentsController extends AppController {
    
            var $name = 'Comments';
            var $scaffold;
    }
    ?>

    Controller Tags umiestnený v súbore /app/controllers/tags_controller.php:

    <?php
    class TagsController extends AppController {
    
            var $name = 'Tags';
            var $scaffold;
    }
    ?>

    Skúste si zadať do url prehliadača napríklad adresy www.tvoja-adresa/articles, www.tvoja-adresa/comments alebo www.tvoja-adresa/users. Aké jednoduché však? Scaffolding je mocný nástroj tohto frameworku a dokáže nám značne uľahčiť prácu pri návrhu zložitejších vzťahov v databáze, preto určite stojí zato ho v ranom štádiu vývoja používať.

    Záver

    link

    Týmto je náš náš návrh databázy kompletný a v budúcej časti seriálu sa bližšie pozrieme na zvyšné dve časti architektúry MVC a to konkrétne Controller a View.

           

    Hodnocení: 100 %

            špatnédobré        

    Nástroje: Tisk bez diskuse

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    18.6.2008 12:36 JoHnY2
    Rozbalit Rozbalit vše Re: CakePHP: tvoríme CMS - 4 (Model)
    Chtel bych se zaptat zadrhej (pro me extremni) vetsiny MVC frameworku. Jak resit navrhy aplikaci nad existujicima databazema, se kterejma se neda hejbat. Vetsina MVC implementujicich nejakym zpusobem Model neni vubec schopna zit nad databazi, ktera se nedrzi jejich konvenci.

    Jak je na tom Cake, pripadne nevite po jakym PHP frameworku bych se mel podiva ?

    V blizky dobe si na me brousi zuby hromada staryho kodu, kterej bude potreba nad stavajicima databazema pretvorit na neco lepsiho nez HTML3.2 + PHP3.
    18.6.2008 13:19 tatramat
    Rozbalit Rozbalit vše Re: CakePHP: tvoríme CMS - 4 (Model)
    v $useTable nemusi byt nazvy tabulek danych konvenci. pak je take mozne $primaryKey='muj_primary_key' v has/belongs je tez mozno definovat vlastni foreignKey... koneckoncu, muzete si napsat vlastni VirtualModel a v nem si vse osetrit po svem a dalsi modely derivovat z Virtualu.

    vice viz http://api.cakephp.org
    Daniel Kvasnička ml. avatar 19.6.2008 14:04 Daniel Kvasnička ml. | skóre: 52 | blog: The Joys and Sorrows of Being an IT Freak | Ostrava
    Rozbalit Rozbalit vše Re: CakePHP: tvoríme CMS - 4 (Model)
    Vyzkousej Propel. Sice konkretne schopnost reverzniho zkoumani existujici DB (http://propel.phpdb.org/trac/wiki/Users/Documentation/1.3/HowTos/ExistingDatabases) jsem u nej jeste nepouzil, ale jinak je to paradni ORM knihovna.

    I kdyby reverzni nevyslo, muzes rucne napsat propelovske XML schema podle sve databaze. Propel te nijak omezovat nebude.
    FSF: “screw you for not wanting the stuff we produce”, People: “screw you for not producing the stuff we want."
    18.6.2008 18:27 alexovi
    Rozbalit Rozbalit vše Re: CakePHP: tvoríme CMS - 4 (Model)
    "Predstavme si, že každý článok má svojho autora. Čiže budeme mať dve tabuľky a to articles a users"

    Chcel by som poprosit autora aby si po sebe skontroloval co napise. Uz som si to vsimol aj v minulom clanku (v obrazkoch). Ano viem, ze si to mozem domysliet. ale je to zbytocne matuce.
    18.6.2008 18:35 alexovi
    Rozbalit Rozbalit vše Re: CakePHP: tvoríme CMS - 4 (Model)
    No pozeram, ze k tomu zmateniu u mna doslo. V minulej casti bola tabulka s autormi nazvana authors a z tabulky articles sa do nej odkazovala cez user_id (posledne 2 obrazky). V dnesnej casti uz sa aspon pouziva user konzistentne.
    18.6.2008 20:36 Tibor Piňo | skóre: 26 | blog: Iron_Maiden
    Rozbalit Rozbalit vše Re: CakePHP: tvoríme CMS - 4 (Model)
    Dakujem za upozornenie. Samozrejme to po sebe citam :-) a taktiez to po mne cita vela ludi, ale zatial si to nikto nevsimol. Samozrejme sa to budem snazit opravit co najskor. Dakujem za pozorne citanie :-)
    4.7.2008 09:02 LJ
    Rozbalit Rozbalit vše Re: CakePHP: tvoríme CMS - 4 (Model)
    Mám dvě otázky:

    1. Jak by se soubory controlleru, modelu a view jmenovaly a jak by vypadaly, pokud bych chtěl ukládat do více tabulek najednou. Příklad: Formulář skladové příjemky s skládá z jedné hlavičky a n položek (jejich počet předem neznám) Samozřejmě se celá příjemka musí uložit v jediné transakci (nepoužívám MySQL ale Oracle) například do tabulek doklad_hlavicka (do té uložím data z hlavičky dokladu) a doklad_radek (do té uložím n záznamů s daty jednotlivých řádků dokladu). Můžete mi někdo naznačit, jak by tato struktura v cakePHP vypadala?

    2. Co v případě, že vazební tabulka pro vazbu M:N neobsahuje pouze vazební klíče, ale i další informace o vazbě (naprosto běžná situace)
    8.7.2008 23:31 tatramat
    Rozbalit Rozbalit vše Re: CakePHP: tvoríme CMS - 4 (Model)
    mam jednu odpoved: co se trochu pidit? http://book.cakephp.org/view/66/models
    24.7.2008 09:54 tatramatka
    Rozbalit Rozbalit vše Re: CakePHP: tvoríme CMS - 4 (Model)
    a kdy se muzeme tesit na dalsi dil? mesic v cudu a kde nic tu nic...

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.