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 60014×
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:
- Pomocí výběrového dotazu vyberou odpovídající data
- 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
|
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ů
28.11.2018 23:56 /František Kučera Prosincový sraz spolku OpenAlt se koná ve středu 5.12.2018 od 16:00 na adrese Zikova 1903/4, Praha 6. Tentokrát navštívíme organizaci CESNET. Na programu jsou dvě přednášky: Distribuované úložiště Ceph (Michal Strnad) a Plně šifrovaný disk na moderním systému (Ondřej Caletka). Následně se přesuneme do některé z nedalekých restaurací, kde budeme pokračovat v diskusi.
Komentářů: 1
12.11.2018 21:28 /Redakce Linuxsoft.cz 22. listopadu 2018 se koná v Praze na Karlově náměstí již pátý ročník konference s tématem Datová centra pro business, která nabídne odpovědi na aktuální a často řešené otázky: Jaké jsou aktuální trendy v oblasti datových center a jak je optimálně využít pro vlastní prospěch? Jak si zajistit odpovídající služby datových center? Podle jakých kritérií vybírat dodavatele služeb? Jak volit vhodné součásti infrastruktury při budování či rozšiřování vlastního datového centra? Jak efektivně datové centrum spravovat? Jak co nejlépe eliminovat možná rizika? apod. Příznivci LinuxSoftu mohou při registraci uplatnit kód LIN350, který jim přinese zvýhodněné vstupné s 50% slevou.
Přidat komentář
6.11.2018 2:04 /František Kučera Říjnový pražský sraz spolku OpenAlt se koná v listopadu – již tento čtvrtek – 8. 11. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma umění a technologie, IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář
4.10.2018 21:30 /Ondřej Čečák LinuxDays 2018 již tento víkend, registrace je otevřená.
Přidat komentář
18.9.2018 23:30 /František Kučera Zářijový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 20. 9. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář
9.9.2018 14:15 /Redakce Linuxsoft.cz 20.9.2018 proběhne v pražském Kongresovém centru Vavruška konference Mobilní řešení pro business.
Návštěvníci si vyslechnou mimo jiné přednášky na témata: Nejdůležitější aktuální trendy v oblasti mobilních technologií, správa a zabezpečení mobilních zařízení ve firmách, jak mobilně přistupovat k informačnímu systému firmy, kdy se vyplatí používat odolná mobilní zařízení nebo jak zabezpečit mobilní komunikaci.
Přidat komentář
12.8.2018 16:58 /František Kučera Srpnový pražský sraz spolku OpenAlt se koná ve čtvrtek – 16. 8. 2018 od 19:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát jsou tématem srazu databáze prezentaci svého projektu si pro nás připravil Standa Dzik. Dále bude prostor, abychom probrali nápady na využití IoT a sítě The Things Network, případně další témata.
Přidat komentář
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ář
Více ...
Přidat zprávičku
Poslední diskuze
31.7.2023 14:13 /
Linda Graham iPhone Services
30.11.2022 9:32 /
Kyle McDermott Hosting download unavailable
13.12.2018 10:57 /
Jan Mareš Re: zavináč
2.12.2018 23:56 /
František Kučera Sraz
5.10.2018 17:12 /
Jakub Kuljovsky Re: Jaký kurz a software by jste doporučili pro začínajcího kodéra?
Více ...
|