Re: Closes Match

From: Bruno Wolff III <bruno(at)wolff(dot)to>
To: Christian Rusa <christian(at)rusa(dot)at>
Cc: pgsql-sql(at)postgresql(dot)org
Subject: Re: Closes Match
Date: 2005-07-25 17:49:52
Message-ID: 20050725174952.GA23263@wolff.to
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

On Mon, Jul 25, 2005 at 19:31:11 +0200,
Christian Rusa <christian(at)rusa(dot)at> wrote:
> Hi there,
>
> I want to match a string against the database and get the closest
> (shorter) match.
> I was asking myself if its possible to realise this in SQL.
>
> So if the string is:
> abcdefg
>
> And in the database are entries like:
> a
> ab
> abc
>
> I just want to get back 'abc'.
>
> I looked around in the internet and the documentation but found no solution.

You could ORDER BY the length of the strings descending and use LIMIT
to return only one row.

You can write a regular expression to do the matching. Something like:
^(a(b(c(d(e(fg?)?)?)?)?)?$

In response to

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Jonathan Lam 2005-07-25 18:57:11 Re: Closes Match
Previous Message Christian Rusa 2005-07-25 17:31:11 Closes Match