Re: Wildcard LIKE and Sub-select - Mailing list pgsql-sql

From Erik Jones
Subject Re: Wildcard LIKE and Sub-select
Date
Msg-id 4554A246.3010701@myemma.com
Whole thread Raw
In response to Wildcard LIKE and Sub-select  ("Travis Whitton" <tinymountain@gmail.com>)
Responses Re: Wildcard LIKE and Sub-select
List pgsql-sql
Travis Whitton wrote:
> Hi everybody,
> I have two tables of the following structure:
>
> Table "keywords"
>
> column   | type
> ---------------------
> id           | integer
> keyword | varchar(255)
>
> and
>
> Table "badwords"
>
> column   | type
> ----------------------
> badword  | varchar(255)
>
>
> I need to delete all the rows from the keywords table where badword 
> partially matches the keyword field. I know I can do an exact match 
> with a sub-select, but I'm not sure how to structure a wildcard match 
> / like clause with a sub-select. Also, is that the best way to do it, 
> or should I be looking into full-text? I have roughly 10 million 
> keywords and 1 million badwords.
>
> Thanks,
> Travis
>
Hmm...  Maybe (this is untested):

DELETE FROM keywords
USING badwords
WHERE keyword ILIKE ANY (SELECT '%' || badword || '%'                                                  FROM badwords)

-- 
erik jones <erik@myemma.com>
software development
emma(r)



pgsql-sql by date:

Previous
From: "A. Kretschmer"
Date:
Subject: Re: Between and miliseconds (timestamps)
Next
From: "Travis Whitton"
Date:
Subject: Re: Wildcard LIKE and Sub-select