Regular Expression Match Operator escape character

From: "Gnanakumar" <gnanam(at)zoniac(dot)com>
To: <pgsql-sql(at)postgresql(dot)org>
Subject: Regular Expression Match Operator escape character
Date: 2010-12-08 13:51:44
Message-ID: 006601cb96df$0fd82cd0$2f888670$@com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Hi,

We're running PostgreSQL v8.2.3 on RHEL5.

In some places in our application, we use Regular Expression Match Operator
(~* => Matches regular expression, case insensitive) inside WHERE criteria.

Example:
SELECT ...
FROM ...
WHERE (SKILLS ~*
'(^|\\^|\\||[^0-9|^a-z|^A-Z]|$)C#(^|\\^|\\||[^0-9|^a-z|^A-Z]|$)'
OR SKILLS ~*
'(^|\\^|\\||[^0-9|^a-z|^A-Z]|$).NET(^|\\^|\\||[^0-9|^a-z|^A-Z]|$)')

In this case, we're trying to search/match for either "C#" OR ".NET" in
SKILLS column.

My question here is, do I need to escape the characters "#" and "." here?

Regards,
Gnanam

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Marc Mamin 2010-12-08 14:06:33 Re: conditional aggregates
Previous Message Marcin Krawczyk 2010-12-08 13:19:49 Re: conditional aggregates