Re: [GENERAL] Tsearch not searching 'Y' - Mailing list pgsql-sql

From John Gage
Subject Re: [GENERAL] Tsearch not searching 'Y'
Date
Msg-id 4D5A9366-9110-4FA4-8445-E408E2C2FEE9@numericable.fr
Whole thread Raw
In response to Re: Tsearch not searching 'Y'  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-sql
You can avoid stemming by using 'simple' instead of 'english' as the
language of the words in to_tsvector (which is a little more awkward
than the cast).

"There are no stop words for the simple dictionary. It will just
convert to lower case, and index every unique word.
SELECT to_tsvector('simple', 'Andy andy The the in out');
  to_tsvector
  -------------------------------------
  'in':5 'out':6 'the':3,4 'andy':1,2
(1 row)

John


On Apr 29, 2010, at 4:01 PM, Tom Lane wrote:

> "sandeep prakash dhumale" <sandy9940@rediffmail.com> writes:
>> I am trying to get tsearch working for my application but I am
>> facing a
>> problem when alphabet 'Y' is the in the tsquery.
>
>> # SELECT 'hollywood'::tsvector  @@ to_tsquery('holly:*');
>> ?column?
>> ----------
>> f
>> (1 row)
>
> You can't use to_tsquery for this sort of thing, because it tries to
> normalize the given words:
>
> regression=# select to_tsquery('holly:*');
> to_tsquery
> ------------
> 'holli':*
> (1 row)
>
> If you do this it works:
>
> regression=# SELECT 'hollywood'::tsvector  @@ 'holly:*'::tsquery;
> ?column?
> ----------
> t
> (1 row)
>
> So if you want to use prefix matching, don't normalize.
>
>             regards, tom lane
>
> --
> Sent via pgsql-sql mailing list (pgsql-sql@postgresql.org)
> To make changes to your subscription:
> http://www.postgresql.org/mailpref/pgsql-sql


pgsql-sql by date:

Previous
From: Kenneth Marshall
Date:
Subject: Re: Tsearch not searching 'Y'
Next
From: E H
Date:
Subject: [GENERAL] Schema design / joins