PostgreSQL (11) - Výběr pomocí vzorků
V tomto díle bude probrán výběr porovnáním textů se vzorky, nejen jednoduchými. ale i těmi, které umí způsobit mnoha programátorům bolení hlavy - regulárními výrazy, s ohledem na jejich použití v PostgreSQL serveru.
13.6.2005 11:00 |
MaReK Olšavský
| Články autora
| přečteno 12201×
Komerční sdělení: Pořádáme Kurzy PgSQL
PostgreSQL server na rozdíl od MySQL, zcela určitě i dalších,
nepodporuje fulltextové vyhledávání, což se může zdáti nevýhodou, ale
není tomu tak. V MySQL, kde je tato funkce, v rámci některých
(webových) projektů, využívána to obnáší použití speciální indexace,
což není ještě nejvážnější problém, ale při použití této vlastnosti
jako takové lze velmi často narazit na problémy při použití národních
znakových sad.
Vyhledávání na PostgreSQL lze realizovat velice jednoduše, použitím
funkcí LIKE a SIMILAR TO, přičemž přetím je třeba si předtím vstupní řetězec,
sestává-li se z více slov, rozdělit na jednotlivé části, to lze
realizovat buď zpracováním na úrovni aplikace, případně pomocí stored
procedury na straně serveru (dle názoru autora se jedná o vhodnější
způsob a uloženým procedurám bude věnována značná část seriálu.
Regulární výrazy
Zápis ^.+@.+\\..+$ může způsobit většině začínajících
programátorů menší bolení hlavy, jedná se však o nejjednodušší možný
regulární výraz, kterým se dá ověřit, zda-li je řetězec korektně
zapsanou e-mailovou adresou (ověřit její existenci je věc trochu jiná).
Samozřejmě, že i tento regulátní výraz lze napsat o něco složitěji a
korektněji, protože v tomto případě bude jako validní mail vyhodnocen i
řetězec 'ja@b..cz'.
Regulární výrazy si lze představit, jako obecné vzorky, které
postihují tvar řetězce, poměrně pěknou začátečnickou příručku na
regulární výrazy napsal Pavel Satrapa, k nalezení je na jeho stránkách.
Zde v pár odstavcích bude pouze to nejjednodušší možné. Vzorky mohou
být jednoduché, popisující jen znakové řetězce, případně velmi složité,
popisující i opakování částí řetězce, jejich zrcadlení, atp.
Nejprve budou uvedeny alespoň některé řídící znaky používané v
regulárních výrazech (a jejich přesný výraz je určen pozicí ve vzorku):
- ^ - Následující znak(y) jsou počáteční v řetězci, případně
nebud(e/ou) obsažen(y)
- $ - Předcházející sekvence znaků je konec řetězce
- . - (Tečka) Libovolný znak kromě konce řádku, tečka
- \ - escape, mění význam znaku za lomítkem, takže například
pro vyhledání tří teček se nepoužívá sekvence '...', ale '\.\.\.'
- * - opakování (!nula a vícekrát)
- + - opakování (jednou a vícekrát)
- ? - opakování nula, či jedenkráte
- () - seskupení znaků do logických jednotek
- [] - uzavření znakové třídy
- | - Nebo, oddělení dvou variant
- {} - Počet opakování
Protože velmi kvalitní informace o regulárních výrazech má ve své
příručce Pavel Satrapa, bude zde rozsah omezen jen na několik příkládků
s vysvětlením. PostgreSQL server umí regulární výrazy podle zvyklostí v
jazyce Perl a v systému POSIX, proto mohou při zápise stejném, jako v
PHP vzniknout určité chyby a nefunkčnosti.
Příklady:
- ^ahoj - všechny řetězce začínající slovem ahoj
- konec$ - všechny řetězce končící sekvencí konec
- ^t[e|á]ta - vyhoví věty začínající slovy táta i teta
- ^.?r(\. ){0,1}nec$ - vyhoví slova 'rnec', 'srnec', 'hrnec' i 'dr. nec'
- ^[0-3]?[0-9](\.)( )?[0-1]?[0-9]\.$ - datum ve tvaru dd. mm, ale nekorektně, povolí třeba zápis 37. 19., správnější tvar je tedy ^(([0-2]?[0-9])|(3[01]))(\.)( )?((0?[0-9])|(1[012]))$
- ^([a-zA-Z0-9_-]+)(\.[a-zA-Z0-9_-]+)*@([a-zA-Z0-9_-]+\.)+[a-zA-Z]{2,5}$- ověření, zda-li se jedná o správně zapsanou e-mailovou adresu (trochu korektněji).
Vyhledávání pomocí vzorků
Vyhledání pomocí vzorku
Pokud je přesně známá alespoň část řetězce, lze v části WHERE použít
příkaz LIKE, případně NOT LIKE pro vyloučení z výběru, pro výběr, je-li
známa alespoň část řetězce. A tato musí být známa přesně!! Protože pro
přesně určení lze použít přímo sekveci ...WHERE colx='slovo',
nabízí příkaz LIKE, použití tzv. žolíků, nebo-li divokých znaků. Tyto
znaky jsou 2 (slovem dva), '_' (podtržítko) pro nahrazení jednoho znaku
a '%' pro nahrazení libovolného počtu znaků. Pokud je třeba některý ze
zástupných znaků vložit jako znak pro vyhledání, je nutné jej
odescapovat vložením znaku '\' (zpětné lomítko), ale i tento escapovací
znak lze změnit použitím klazule ESCAPE. Pokud je potřeba mít příkaz
LIKE (a NOT LIKE) nezávislé na velikosti písmen, stačí přidat písmeno
'I' (odvozeno od insensitive), tj. ILIKE a NOT ILIKE.
Podobně jako příkaz LIKE funguje i SIMILAR TO, který je v normě
SQL99, jeho použití není stejné jako LIKE, ale tak trochu naznačuje, co
umožňují regulární výrazy. Kromě zástupných znaků '%' a '_' jsou
definovány i některé další znaky z regulárních výrazů: '|', '*', '+' ,
'()' a '[]'. Toto jsou všechny znaky a bloky, které SIMILAR TO
podporuje, popis komplexního vyhledávání pomocí regulárních výrazů je
dále.
Použití LIKE a SIMILAR TO bude nejlépe viditelné na konkrétních
příkladech, které budou zkoušeny na :
SELECT * FROM products WHERE title like 'Slack';
SELECT * FROM products WHERE title like 'Slack%';
SELECT * FROM products WHERE title not ilike 'slack%';
SELECT * FROM products WHERE title SIMILAR TO '%(Ve)%';
Vyhledávání regulárními výrazy
Pro porovnání pole z databázové věty vůči vzorku se používá operátor
'~' (tilda/vlnovka) s několika modifikátory - '!' (vykřičník) pro
negaci a '*' (hvězdička) pro nerozlišování malých a velkých písmen. Pro
vyhledávání se nepoužívá klíčové slovo LIKE (), SIMILAR TO.
Použití vyplyne opět nejlépe z příkladů:
SELECT * FROM products WHERE description ~ '\.\.\.';
SELECT * FROM products WHERE description !~
'([a-zA-Z0-9_-]+)(\.[a-zA-Z0-9_-]+)*@([a-zA-Z0-9_-]+\.)+[a-zA-Z]{2,5}';
SELECT * FROM products WHERE description !~* 'slack';
Vysvětlení je takovéto. V první
příkladě jsou vybrány všechny položky, které mají v popisu ... (tři
tečky), v druhém jsou vybrány ty, kde není v popisu uveden e-mail a ve
třetím ty, které neobsahují slovo 'slack', s ignorováním malých a
velkých písmen.
Poznámka
Regulární výrazy lze v příkazu
SELECT použít nejen pro vyhledávání záznamů, ale i pro získávání částí
řetězců, pomocí funkce substring.
Další využití (trochu složitější je) při tvorbě tabulky vytvořit
donucující omezení (constrains), které budou data kontrolovat ihned při
vkládání záznamů do tabulky. Protože se jedná o malinko složitější
záležitosti, a ne nutné při prvních krocích s databází, je tato
problematika odložena na později.
Závěr
Tento díl byl o něco kratší,
než je běžným zvykem tohoto seriálu, ale vzhledem k tomu, že regulární
výrazy nejsou elementární a zcela jednoduchou záležitostí, budou mít
čtenáři o dostatek studijního materiálu bohatě postaráno. Protože
regulární výrazy jsou tématem na vlastní seriálek...
Verze pro tisk
| |
Příspívat do diskuze mohou pouze registrovaní uživatelé.
|
|

Vyhledávání software

Vyhledávání článků
22.5.2013 6:46 /MaReK Olšavský Svobodný software ve státní sféře nejsou jen vítězství, ale i mýty a pověry, které jej vylučují z výběru. 5 nejčastějších hloupostí o F/L/OSS zkritizoval Adam Firestone na stránkách OpenSource.com. Nesetkáváme se s podobnými argumenty i při snaze prosadit svobodný software ve firmách a u soukromých osob?
Přidat komentář
22.5.2013 6:46 /MaReK Olšavský Embedovatelná databáze SQLite byla vydána ve verzi 3.7.17, která nabízí větší rychlost (v některých úlohách až dvojnásobnou), opravy několika chyb, nebo vylepšení možností nahrávání rozšíření. O SQLite se píše výrazně méně, než o konkurenci, ale velmi pravděpodobně jde o nejčastěji nasazené řešení, díky mnoha aplikacím.
Přidat komentář
22.5.2013 6:45 /MaReK Olšavský 14. května 2013 IBM oznámila konec vývoje Lotus SmartSuite , Lotus Organizer a Lotus 1-2-3, balíků aplikací, jež byly považovány za špičku v oboru. Krátký nekrolog za legendární Lotus 1-2-3, který byl vyvíjen 30 let, sepsal Steven J. Vaughan-Nichols.
Přidat komentář
21.5.2013 7:05 /MaReK Olšavský Vydání nástupce kdysi velmi populární distribuce GNU/Linuxu, Mandrake/Mandrivy, Mageia již nebude dále odkládáno, s 2 měsíčním zpožděním vyšla Mageia 3. Z novinek vybíráme: KDE 4.10.2, GNOME 3.6, LibreOffice 4.03, nebo Steam pro Linux. Mageia patří mezi distribuce, které lze doporučit méně zkuženým uživatelům.
Přidat komentář
21.5.2013 7:05 /MaReK Olšavský Chytré telefony s operačním systémem Sailfish OS (který vytváří společnost Jolla, jež vznikla z bývalých vývojářů Maema Nokie) se blíží uvedení na trh, předobjednávka s dodáním na konci roku 2013 a kompatibilita s Androidími aplikacemi ukazují na blízkost cíle. Rozhovor s Marcem Dillonem odhaluje mnohé z pozadí vývoje. Není bez zajímavosti, že první aplikace byla zveřejněna pouhých 29 minut po vydání SDK.
Přidat komentář
21.5.2013 7:05 /MaReK Olšavský Z koupě populární služby Tumblr firmou Yahoo za 1,1 mld. US$ nemalou měrou těží svobodný Wordpress, jemuž narostl počet importovaných blogů z Tumblr přibližně 150×.
Přidat komentář
21.5.2013 7:05 /MaReK Olšavský Ač se to mnohým může zdát neuvěřitelné, COBOL stále patří mezi živé jazyky. Firma IBM rozšířila jeho schopnosti o podporu XML a Javy 7, se současným nárůstem výkonu o 15—20 %.
Přidat komentář
20.5.2013 6:53 /MaReK Olšavský Vývojářský tým NetBSD vydal verzi 6.1 operačního systému, jenž je portován pro drtivou většinu používaných platforem. Jelikož se jedná o upgrade stávající řady, přináší nová verze převážně jen opravy. V duchu oprav vydání vyšla i verze 6.0.2.
Přidat komentář
Více ...
Přidat zprávičku
 Poslední diskuze
18.5.2013 17:55 /
Martin Kumst Re: zaheslování bash scriptu nebo složky
18.5.2013 7:44 /
--- Re: Prosím o pomoc či radu
15.5.2013 19:21 /
Filip Vaněček Cesty k souborům při používání coolurl
13.5.2013 6:50 /
Radim Kolář Zabbix
8.5.2013 6:07 /
MaReK Olšavský Web Upd8
Více ...
|