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

> MySQL (13) - Vkládáme data

Databázi už máme, teď nějaká data. Jak je vkládat a na co přitom dávat pozor - o tom je dnešní díl seriálu o MySQL.

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

Vkládání dat je jedním z pilířů práce s databázemi. Ostatně databáze bez dat by byla k ničemu. Proto je velmi důležité naučit se, jak vlasntě jednotlivé informace do databáze dostat. V MySQL právě k tomu slouží příkaz INSERT.

Příkaz INSERT

Zkusme to nejprve na nějakém učebnicovém příkadu. Dejme tomu, že si budete chtít pořídit seznam všech knih ve vaší knihovničce. Ještě předtím, než budete moci cokoli vkládat, je potřeba vytvořit odpovídající databázi a vytvořit odpovídající tabulku.

create database knihovna;
use knihovna;
create table knihy (id int not null auto_increment,
nazev varchar (50), autor varchar(50), primary key (id));

S tímto arzenálem už můžete začít do tabulky vkládat informace o jednotlivých knihách. Děje se tak pomocí příkazu INSERT. Jeho nejběžnější forma je:

insert into knihy (nazev, autor) values ('LINUX - dokumentační projekt', 'kolektiv autorů');

V praxi to většinou probíhá tak, že příkaz INSERT je sestaven nějakou klientskou aplikací a odeslán databázi ke zpracování. Odkud by data pro příkaz INSERT mohla pocházet? To je velmi různorodé. Pokud by byla MySQL použita ve webové aplikaci, je dost dobře možné, že data pro příkaz INSERT budou pocházet z formuláře na webové stránce. Jestliže by se jednalo o desktopovou aplikaci s grafickým rozhraním, mohou data pocházet z textových polí nebo mřížek; jestliže bude MySQL použita v obchodním domě na evidenci prodejů zboží, pak poputují do databáze data ze čteček čárového kódu a podobně. V každém případě je třeba kontrolovat vkládané údaje ještě předtím, než jsou do databáze vloženy.

Pozn.: Existuje ještě jedna odlišná filozofie přístupu k věci - vložit někam data co nejrychleji (možná do dočasné tabulky) a nechat je zkontrolovat, až na to bude čas. Tento postup je někdy k vidění u velmi zatížených aplikací, ale příliš mi k srdci nepřirostl.

Příkazem INSERT lze rovněž vložit více než jeden řádek. Tento trik není příliš známý. Funguje to takto:

insert into knihy (nazev, autor)
values ('PHP - tvorba interaktivních internetových aplikací', 'Jiří Kosek'),
('Myslíme v jazyku MySQL', 'Ian Gilfillan');

Za zmínku rovněž stojí, že v příkazu INSERT nemusíme specifikovat všechny sloupce. V příkladu výše jsme neurčili, co se má vložit do sloupce id. Protože to je sloupec, kam se vkládají čísla automaticky, vlastně to vůbec nevadí. Co však vloží INSERT do sloupců, které nejsou typu autoincrement, když jim nic nespecifikujeme? Funguje to takto:

  • U sloupců, kde je povoleno mít hodnoty NULL bude vložena hodnota NULL.
  • U sloupců, kde není povoleno mít hodnoty NULL bude vložena výchozí hodnota pro daný typ sloupce (například 0 pro celá čísla)
  • U sloupců, které mají definovánu výchozí hodnotu DEFAULT pomocí příkazu CREATE TABLE nebo ALTER TABLE bude vložena definovaná hodnota.
  • U sloupců typu ENUM bude vložena první hodnota v seznamu.

Příkaz INSERT ... SELECT

Další varianta příkazu INSERT spočívá v tom, že se mohou vkládat do tabulky data, která již v jiné tabulkce (nebo jiných tabulkách, nebo dokonce ve stejné tabulce) existují. Jde se na to tak, že se:

  1. Pomocí výběrového dotazu vyberou odpovídající data
  2. Ta se vloží do tabulky pomocí speciální syntaxe příkazu INSERT.

Problém s výběrovými dotazy je ten, že jsme o nich v seriálu zatím nemluvili. Nicméně, krátká ukázka by mohla vypadat nějak takto:

INSERT INTO archiv_faktur SELECT * FROM faktury;

Jedná se o to, že data jsou nejprve vybrána ze zdrojové tabulky (tabulek) a následně vložena do tabulky cílové. Zdroj velmi často obsahuje více než jeden záznam, takže je běžné, že se takto pracuje s velkými objemy dat. Platí přitom, že výběrový dotaz (to je ta část od slova SELECT) musí obsahovat stejně sloupců jako tabulka, do níž se vkládá a že datové typy souvisejících sloupců musejí být stejné nebo schopné konverze. Příkaz INSERT ... SELECT je obecně poměrně dost rychlý.

INSERT a výrazy

Nikde není řečeno, že jako součást příkazu INSERT se musejí používat data zapsaná ručně nebo data vybraná z nějaké tabulky. Jako součást příkazu mohou stejně tak posloužit výrazy. Máme-li tedy tabulku:

create table vypocty (vysledek int);

bude jakákoli z následujících syntaxí platná:

insert into vypocty values (1+2);
insert into vypocty values (3*4);
insert into vypocty values (20/5);

Neboli, v příkazu INSERT, stejně jako na mnoha dalších místech v databázi mohou být výsledky nějakého výpočtu. Co všechno umí databáze počítat si ještě postupně ukážeme. Nechat výpočty na databázi může být, zejména v případě vkládání většího počtu řádků o dost rychlejší, než kdyby to měla děla dělat klientská aplikace.

Poznámky k příkazu INSERT

Ačkoli je příkaz INSERT poměrně bezbolestný, přesto se vyplatí vědět nějaké ty záludnosti, tipy a triky. Tady jsem jich pár popsal:
  • Příkaz INSERT lze spouštět s celou řadou voleb. Ty se týkají takových věcí, jako je zamykání tabulek, priorita nebo řešení některých chyb. Více je v manuálu.
  • Příkaz INSERT má místy nepřehledné zpracování chyb. Například, jestliže se pokusíte vložit hodnotu NULL pomocí příkazu INSERT do sloupce, kde nesmí být, skončí to chybou. Pokud ale budete vkládat více hodnot pomocí values (...), (...), ty vyhovující záznamy se vloží.
  • Rychlost příkazu INSERT se dá ovlivnit vhodným návrhem tabulky. Obecně je vkládání záznamů tím palčivější problém, čím více je jich potřeba vložit, čím více sloupců tabulka obsahuje a čím více obsahuje indexů (o těch se ještě také něco dozvíme).
  • Prakticky v každém programovacím jazyce, který lze napojit na MySQL existuje způsob, jak testovat, zda se vložení povedlo. Je velmi dobrý nápad to skutečně testovat a reagovat pružně na případné problémy.

Verze pro tisk

pridej.cz

 

DISKUZE

Nejsou žádné diskuzní příspěvky u dané položky.



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

16.7.2018 1:05 /František Kučera

Červencový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 7. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát bude přednáška na téma: automatizační nástroj Ansible, kterou si připravil Martin Vicián.


Přidat komentář

18.6.2018 0:43 /František Kučera
Červnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 21. 6. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: F-Droid, aneb svobodný software do vašeho mobilu. Kromě toho budou k vidění i vývojové desky HiFive1 se svobodným/otevřeným čipem RISC-V.
Přidat komentář

23.5.2018 20:55 /Ondřej Čečák
Od pátku 25.5. proběhne na Fakultě informačních technologií ČVUT v Praze openSUSE Conference. Můžete se těšit na spostu zajímavých přednášek, workshopů a také na Release Party nového openSUSE leap 15.0. V na stejném místě proběhne v sobotu 26.5. i seminář o bezpečnosti CryptoFest.
Přidat komentář

20.5.2018 17:45 /Redakce Linuxsoft.cz
Ve čtvrtek 31. května 2018 připravuje webový magazín BusinessIT ve spolupráci s Best Online Média s.r.o. pátý ročník odborné konference Firemní informační systémy 2018. Akce proběhne v kongresovém centru Vavruška (palác Charitas), Karlovo náměstí 5, Praha 2 (u metra Karlovo náměstí) od 9:00 hod. dopoledne do cca 15 hod. odpoledne. Konference je zaměřena na efektivní využití firemních informačních systémů a na to, jak plně využít jejich potenciál. Podrobnější informace na webových stránkách konfrence.
Přidat komentář

14.5.2018 7:28 /František Kučera
Květnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 17. 5. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: Audio – zvuk v GNU/Linuxu.
Přidat komentář

7.5.2018 16:20 /František Kučera
Na stránkách spolku OpenAlt vyšla fotoreportáž Pražské srazy 2017 dokumentující srazy za uplynulý rok. Květnový pražský sraz na téma audio se bude konat 17. 5. 2018 (místo a čas ještě upřesníme).
Přidat komentář

17.4.2018 0:46 /František Kučera
Dubnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 4. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tématem tohoto srazu bude OpenStreetMap (OSM) aneb svobodné mapy.
Přidat komentář

16.3.2018 22:01 /František Kučera
Kulatý OpenAlt sraz v Praze oslavíme klasicky: u limonády a piva! Přijďte si posedět, dát si dobré jídlo a vybrat z mnoha piv do restaurace Kulový blesk, který najdete v centru Prahy nedaleko metra I. P. Pavlova na adrese Sokolská 13, Praha 2. Sraz se koná ve čtvrtek 22. března a začínáme v 18:00. Heslo: OpenAlt. Vezměte s sebou svoje hračky! Uvítáme, když si s sebou na sraz vezmete svoje oblíbené hračky. Jestli máte nějaký drobný projekt postavený na Arduinu, nějakou zajímavou elektronickou součástku, či třeba i pěkný úlovek z crowdfundingové akce, neváhejte. Oslníte ostatní a o zábavu bude postaráno.
Přidat komentář

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

> Poslední diskuze

20.2.2018 18:48 / Ivan Majer
portal

20.2.2018 15:57 / Jan Havel
Jak využíváte služby cloudu v podnikání?

16.1.2018 1:08 / Ivan Pittner
verejna ip od o2 ubuntu

15.1.2018 17:26 / Mira Harvalik
Re: Jak udělat HTML/Javascript swiping gallery do mobilu?

30.12.2017 20:16 / Michal Knoll
odmocnina

Více ...

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