Plpgsql: Assign regular expression match to variable - Mailing list pgsql-sql

From Leif B. Kristensen
Subject Plpgsql: Assign regular expression match to variable
Date
Msg-id 200909011401.00231.leif@solumslekt.org
Whole thread Raw
Responses Re: Plpgsql: Assign regular expression match to variable  (Ian Barwick <barwick@gmail.com>)
List pgsql-sql
In Plpgsql, I've got this problem of how to assign an integer extracted 
from a regex to a variable. My approach so far feels kludgy:

-- extract ^#(\d+) from txt
IF txt SIMILAR TO E'#\\d+%' THEN   my_int := SUBSTR(SUBSTRING(txt, E'#\\d+'), 2,       LENGTH(SUBSTRING(txt, E'#\\d+'))
-1)::INTEGER;  -- strip ^#\d+ from text   my_txt := REGEXP_REPLACE(txt, E'^#\\d+ ', '');
 
END IF;

What I'd like to do is something like this:

my_int := MATCH(txt, '^#(\d+)')::INTEGER;

which would assign the integer atom (\d+) to my_int.
-- 
Leif Biberg Kristensen | Registered Linux User #338009
Me And My Database: http://solumslekt.org/blog/


pgsql-sql by date:

Previous
From: Pavel Stehule
Date:
Subject: Re: PostgreSQL Function: how to know the number of the returned results of the Query
Next
From: Ian Barwick
Date:
Subject: Re: Plpgsql: Assign regular expression match to variable