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

> 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 18219×

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

pridej.cz

 

DISKUZE

fulltext 13.6.2005 13:17 Tomas Konir
L Re: fulltext 13.6.2005 13:41 MaReK Olšavský
Negace 13.6.2005 20:28 Petr Zajíc
  L Re: Negace 14.6.2005 14:07 MaReK Olšavský




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

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?

20.9.2018 10:04 / Jan Ober
Jaký kurz a software by jste doporučili pro začínajcího kodéra?

20.9.2018 10:00 / Jan Ober
Re: Gimp

20.2.2018 18:48 / Ivan Majer
portal

Více ...

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