LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> PHP (34) - Úvod do databází

V seriálu o PHP se dostáváme k databázím. Dnes to bude lehký úvod do teorie.

6.8.2004 15:00 | Petr Zajíc | Články autora | přečteno 63041×

Komerční sdělení: Pořádáme Kurzy PHP

PHP by určitě nebylo tak rozšířené, kdyby neumělo pracovat s databázemi, zvláště pak s MySQL. Databáze jsou téma velmi rozsáhlé a už to vydalo na mnoho seriálů. My se soustředíme na to, co nám pomůže vybudovat kvalitní PHP-databázový web. Pokud s databázemi aktivně pracujete, budete pravděpodobně schopni tento článek vynechat, pokud ne, čtěte pozorně dál.

Potřeba databází je velmi stará a již v době počítačového pravěku se na sálových počítačích s databázemi pracovalo. Kdybych se pokusil o chabou definici, je databáze cokoli, co obsahuje data. Data neboli údaje jsou v databázích nejen shromážděna, ale obvykle pod pojmem "databáze" chápeme rovněž sadu nástrojů, které nám pomohou s daty pracovat - přidávat je, mazat, upravovat, seskupovat, hledat a podobně.

Pozn.: Mezi "daty" a "informacemi" ve skutečnosti je drobný významový odstín. Data jsou údaje samy o sobě (plat=10000,- Kč), informace zahrnují i postoje k datům ("beru málo"). Existují specializované aplikace zabávající se významem zjišťovaných dat. Těmi se ale v našem seriálu zabývat nebudeme.

Dělení databází

Abychom se v širém světě databází alespoň trochu vyznali, rozdělme si je. Databáze se dají rozdělit (nejméně) podle dvou významných kritérií.

Souborové a systémové
Databáze může být obsažena v jednom nebo několika málo souborech operačního systému. Pak jim říkáme souborové. Databázi dostanete na jiný stroj pouhým překopírováním souboru nebo několika souborů. Typickým zástupcem souborových databází jsou databáze dbf (foxpro), SQLite nebo třebas Microsoft Access. Souborové databáze mívají několik významných omezení, hlavně je to jejich dostupnost v rámci sítě nebo různá úroveň podpory souběžné práce více uživatelů. Abyste mohli pracovat se souborovou databází, převážně platí, že k souboru musíte mít nějaká práva.

Naproti tomu systémové databáze slouží jako databázové servery. Většinou mají velmi dobrou podporu souběžné práce více uživatelů a bývají přístupné pomocí nějakého směrovatelného protokolu (asi TCP). Systémové databáze mívají obecně složitější instalaci, bývají vypiplanější a robustnější. Mezi typické zástupce patří například MySQL, PostgreSQL, Oracle nebo Microsoft SQL server. Obecně se můžete připojit k systémové databázi i v případě, že na systém na němž běží nemáte jinak přístup.

Pozn.: V poslední době se významový rozdíl mezi souborovými a systémovými databázemi dost stírá. Existuje totiž řada způsobů, jak pomocí nějakého software přistupovat k souborovým databázím, jako by to byly databáze systémové. Například pomocí UnixODBC nebo ODBC můžete přistupovat k databázi dbf z počítačové sítě a podobně.

Objektové a relační
Dosti podstatné je rozdělení podle filozofie uložení dat. Méně obvyklý způsob je organizovat data v databázi jako objekty. Zhruba to odpovídá způsobu, jakým jsme o objektech mluvili v souvislosti s PHP. Objektové databáze nejsou příliš rozšířené. Bývá jim vytýkáno, že jsou pomalé. Nemohu to potvrdit ani vyvrátit, protože žádnou objektovou databázi nepoužívám. Zástupcem by mohla být třeba Caché.

Prakticky všechny dnešní databáze jsou relační. Data v relačních databázích jsou (nebo alespoň mohou být) uložena tak, že související záznamy můžete jednoduše vyhledat. Například v databázi podniku můžete k pracovníkům rychle najít šéfy, platové skupiny nebo záznamy o příchodech na pracoviště. Pokud si nedokážete představit, jak to funguje, nedělejte si s tím hlavu. Budeme o tom mluvit příště.

Domluva s databází

Bylo by fajn mít nějaký univerzální jazyk, kterým byste se s databází domluvili. Prostě byste jí řekli, co potřebujete (třeba vybrat nějaká data) a ona by to pochopila bez ohledu na to, jestli je objektová, relační, červená nebo open source (nebo jaká ještě jiná). Takový jazyk skutečně existuje a říká se mu SQL (Structured Query Language, strukturovaný dotazovací jazyk).

SQL je standardizován, ale jak už to ve světě databází bývá, každá konkrétní databáze rozumí určitému "dialektu" SQL. V praxi to není tak hrozné, jak by to mohlo vypadat; většinu základních příkazů můžete pro většinu používanějších databází zadat úplně nebo téměř shodně. Některé databáze mají další rozšíření jazyka SQL, takže toho umí víc nebo stejnou věc umí pomocí kratšího zápisu kódu.

Pozn.: Chci Vám jemně naznačit, že kromě syntaxe PHP se vlastně budeme učit další programovací jazyk. Jazyk, kterému rozumí databáze.

Kterou databázi?

To je téměř neřešitelná otázka. Pro každý typ projektu existuje jiná odpověď. Řekněme si alespoň, jaké podmínky by měla splňovat "databáze snů" pro webové aplikace psané v PHP:

  • Měla by (pokud možno) být GNU/GPL, nebo šířena pod jinou svobodnou licencí.
  • Měla by být schopna pracovat pod různými operačními systémy, hlavně pod Linuxem a jinými Unixy. Když poběží i pod Windows, tím lépe.
  • Měla by být relační
  • Měla by být systémová
  • Měla by být stabilní
  • Měla by podporovat standard SQL
  • Měla by obsahovat solidní správu uživatelů
  • Měla by mít solidní zabezpečení a možnost používat zabezpečené přenosy dat (třeba SSL)
  • PHP by mělo tuto databázi nějak rozumně podporovat
  • Měla by umět ukládat data v různých jazycích, resp. znakových sadách
  • Měla by umět česky řadit
  • Měla by podporovat všechny vymoženosti databází (pohledy, spouště, uložené procedury, transsakce atd.)
  • Měla by být rychlá
  • Měla by k ní existovat solidní dokumentace
  • Měl by jí používat dostatečný počet uživatelů, aby to bylo vyzkoušené.
  • Měly by ji podporovat komerční i free webhostingy.

Jak asi tušíte, taková databáze neexistuje. Můžete se rozvášnit v diskusi pod článkem, ale neexistuje, hlavně proto, že některé nadhozené požadavky jsou jasně protichůdné. Existují ale databáze, které se tomu co bylo řečeno hodně přibližují.

My se budeme zaměřovat na MySQL. MySQL není žádný středobod světa, ale poctivě řečeno má k tomu, co bylo předneseno, poměrně blízko. Takže, pokud se budeme zabývat onkrétní prací s PHP a databází, budu se zmiňovat o MySQL.

Pozn.: Existuje celá řada dalších velice dobrých databází, jako je PostgreSQL nebo Firebird. V jednom nebo několika bodech vytýčených výše však většinou za MySQL zaostávají. Protože je vývoj software v oblasti databází velmi bouřlivý, mohou některé myšlenky z čláku přestat velice rychle platit.

Verze pro tisk

pridej.cz

 

DISKUZE

ne tak jasně 7.8.2004 13:24 Michal Kubeček
|- Re: ne tak jasně 7.8.2004 14:10 František Hucek
| L Re: ne tak jasně 7.8.2004 14:17 Michal Kubeček
|   |- Re: ne tak jasně 7.8.2004 14:50 František Hucek
|   | L Re: ne tak jasně 8.8.2004 11:37 Michal Kubeček
|   L Re: ne tak jasně 7.8.2004 20:48 Petr Zajíc
|- Re: ne tak jasně 7.8.2004 20:43 Petr Zajíc
| L Re: ne tak jasně 8.8.2004 11:49 Michal Kubeček
|   L Re: ne tak jasně 8.8.2004 13:20 Petr Zajíc
L Re: ne tak jasně 9.8.2004 01:24 Jan Houštěk
Souborove databaze 9.8.2004 01:30 Jan Houštěk
  |- Re: Souborove databaze 9.8.2004 20:26 Michal Kubeček
  L Re: Souborove databaze 11.8.2004 20:00 Petr Zajíc




Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

15.5.2017 23:50 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Zajímá tě DIY, CNC, SDR nebo morseovka? Přijď na sraz spolku OpenAlt, který se bude konat ve čtvrtek 18. května od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář

12.5.2017 16:42 /Honza Javorek
PyCon CZ, česká konference o programovacím jazyce Python, se po dvou úspěšných ročnících v Brně bude letos konat v Praze, a to 8. až 10. června. Na konferenci letos zavítá např. i Armin Ronacher, známý především jako autor frameworku Flask, šablon Jinja2/Twig, a dalších projektů. Těšit se můžete na přednášky o datové analytice, tvorbě webu, testování, tvorbě API, učení a mentorování programování, přednášky o rozvoji komunity, o použití Pythonu ve vědě nebo k ovládání nejrůznějších zařízení (MicroPython). Na vlastní prsty si můžete na workshopech vyzkoušet postavit Pythonem ovládaného robota, naučit se učit šestileté děti programovat, efektivně testovat nebo si v Pythonu pohrát s kartografickým materiálem. Kupujte lístky, dokud jsou.
Přidat komentář

2.5.2017 9:20 /Eva Rázgová
Putovní konference československé Drupal komunity "DrupalCamp Československo" se tentokrát koná 27. 5.2017 na VUT FIT v Brně. Můžete načerpat a vyměnit si zkušenosti z oblasti Drupalu 7 a 8, UX, SEO, managementu týmového vývoje, využití Dockeru pro Drupal a dalších. Vítáni jsou nováčci i experti. Akci pořádají Slovenská Drupal Asociácia a česká Asociace pro Drupal. Registrace na webu .
Přidat komentář

1.5.2017 20:31 /Pavel `Goldenfish' Kysilka
PR: 25.5.2017 proběhne v Praze konference na téma Firemní informační systémy. Hlavními tématy jsou: Informační systémy s vlastní inteligencí, efektivní práce s dokumenty, mobilní přístup k datům nebo využívání cloudu.
Přidat komentář

15.4.2017 15:20 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Zajímá tě IoT a radiokomunikace? Přijď na sraz spolku OpenAlt, který se bude konat ve středu 19. dubna od 18:30 v Šenkovně (Sokolská 60, Praha 2).
Přidat komentář

5.3.2017 19:12 /Redakce Linuxsoft.cz
PR: 23. března proběhne v Praze konferenci na téma Cloud computing v praxi. Hlavními tématy jsou: Nejžhavější trendy v oblasti cloudu a cloudových řešení, Moderní cloudové služby, Infrastruktura současných cloudů, Efektivní využití cloudu, Nástrahy cloudových řešení a jak se jim vyhnout.
Přidat komentář

27.2.2017 22:12 /František Kučera
Pozvánka na 137. sraz OpenAlt – Praha: Tentokrát jsme si pro vás připravili neobvyklou akci. Ve středu 1.3. v 17:30 nás přivítá sdružení CZ.NIC ve svých prostorách v Milešovské ulici číslo 5 na Praze 3, kde si pro nás připravili krátkou prezentaci jejich činnosti. Následně navštívíme jejich datacentrum pod Žižkovskou věží. Provedou nás prostory, které jsou běžnému smrtelníkovi nedostupné!
Po ukončení prohlídky se všchni odebereme do hostince U vodoucha, Jagelonská 21, Praha 3 pochutnat si na některém z vybraných piv či dát si něco na zub. Rezervaci máme od 19:30, heslo je OpenAlt.
Ale pozor! Do prostor datového centra máme omezený přístup, dostane se tam pouze 10 lidí! Takže kdo přijde dříve, ten má přednost, a občanky s sebou! Kdo nebude chtít na prohlídku datového centra, může se pomalu přesunout do hostince U vodoucha a u nepřeberné nabídky piv počkat na ostatní.
Přidat komentář

18.1.2017 0:49 /František Kučera
Členové a příznivci spolku OpenAlt se pravidelně schází v Praze a Brně. Fotky z pražských srazů za uplynulý rok si můžete prohlédnout na stránkách spolku. Příští sraz se koná už 19. ledna – tentokrát je tématem ergonomie ovládání počítače – tzn. klávesnice, myši a další zařízení. Také budete mít příležitost si prohlédnout pražský hackerspace Brmlab.
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

15.6.2017 9:34 / Ondřej Havlas
php,

10.6.2017 10:39 / Temple
sell home for cash

11.5.2017 23:32 / lelo
Re: Problém se správcem balíčků

11.5.2017 5:45 / davd mašek
Re: Problém se správcem balíčků

10.5.2017 22:54 / lelo
Re: Problém se správcem balíčků

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2017) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze