ARCHIV |
|||||
Software (10844)
Distribuce (131)
Skripty (697)
Menu
Diskuze
Informace
|
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. 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ýrazyZápis 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):
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:
Vyhledávání pomocí vzorkůVyhledání pomocí vzorkuPokud 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 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ýrazyPro 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ámkaRegulá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ěrTento 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...
Související články
Předchozí Celou kategorii (seriál) Další
PostgreSQL (1) - Historie a pohledy jinam
PostgreSQL (2) - Proč PgSQL, data a relace PostgreSQL (3) - Instalace, základní administrace PostgreSQL (4) - Datové typy, vytvoření tabulek PostgreSQL (5) - Další datové typy a práce s časem i binarními řetězci PostgreSQL (6) - Uložení, aktualizace a mazání dat. PostgreSQL (7) - Výběr dat z databáze PostgreSQL (8) - SELECT II. PostgreSQL (9) – SELECT III PostgreSQL (10) - SELECT IV PostgreSQL 12 - urychlení výběrů PostgreSQL (13) - Na co se zapomnělo PostgreSQL (14) - omezení dat (Constraints) PostgreSQL (15) - Transakce PostgreSQL (16) - Zamykání PostgreSQL (17) - Datový typ pole PostgreSQL (18) - Datový typ pole II PostgreSQL (19) - Vlastní datové typy PostgreSQL (20) - Vlastní datové typy II PostgreSQL (21) - Spojování dotazů PostgreSQL (22) - Poddotazy PostgreSQL (23) - Optimalizujeme rychlost PostgreSQL (24) - Views (Pohledy) PostgreSQL (25) - Administrace skupin a uživatelů PostgreSQL (26) - Rozšiřujeme funkčnost Předchozí Celou kategorii (seriál) Další
|
Vyhledávání software
Vyhledávání článků
28.11.2018 23:56 /František Kučera 12.11.2018 21:28 /Redakce Linuxsoft.cz 6.11.2018 2:04 /František Kučera 4.10.2018 21:30 /Ondřej Čečák 18.9.2018 23:30 /František Kučera 9.9.2018 14:15 /Redakce Linuxsoft.cz 12.8.2018 16:58 /František Kučera 16.7.2018 1:05 /František Kučera
Poslední diskuze
31.7.2023 14:13 /
Linda Graham 30.11.2022 9:32 /
Kyle McDermott 13.12.2018 10:57 /
Jan Mareš 2.12.2018 23:56 /
František Kučera 5.10.2018 17:12 /
Jakub Kuljovsky | |||
ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2024) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze |