| From: | Erik Jones <erik(at)myemma(dot)com> |
|---|---|
| To: | Travis Whitton <tinymountain(at)gmail(dot)com> |
| Cc: | pgsql-sql(at)postgresql(dot)org |
| Subject: | Re: Wildcard LIKE and Sub-select |
| Date: | 2006-11-10 16:01:10 |
| Message-ID: | 4554A246.3010701@myemma.com |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | 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(at)myemma(dot)com>
software development
emma(r)
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Travis Whitton | 2006-11-10 16:07:44 | Re: Wildcard LIKE and Sub-select |
| Previous Message | A. Kretschmer | 2006-11-10 15:24:28 | Re: Between and miliseconds (timestamps) |