Re: How do I use parameterized queries with LIKE?

Поиск
Список
Период
Сортировка
От Daniele Varrazzo
Тема Re: How do I use parameterized queries with LIKE?
Дата
Msg-id CA+mi_8bD6PNf3CYDA3geq=gTT3JVbB7z7kK485QkYD_Bpi00QQ@mail.gmail.com
обсуждение исходный текст
Ответ на How do I use parameterized queries with LIKE?  ("W. Matthew Wilson" <matt@tplus1.com>)
Ответы Re: How do I use parameterized queries with LIKE?  ("W. Matthew Wilson" <matt@tplus1.com>)
Список psycopg
On Mon, May 28, 2012 at 11:00 PM, W. Matthew Wilson <matt@tplus1.com> wrote:

> But when I move the "matt" part out and use a %s symbol instead, I get
> this error:
>
>    ValueError: unsupported format character ''' (0x27) at index 73
>
> What is the right solution here?

If you have parameters in the query, % is used as placeholder prefix.
You must use %% to include a literal % in the query:

    In [14]: cur.execute("""select email_address from customer where
        email_address like '%%' || %s || '%%'""", ('matt',))

or you can add the % to the value instead of the query:

    In [17]: cur.execute("""select email_address from customer where
        email_address like %s""", ('%matt%',))

Hope this helps,

-- Daniele

В списке psycopg по дате отправления:

Предыдущее
От: Adrian Klaver
Дата:
Сообщение: Re: How do I use parameterized queries with LIKE?
Следующее
От: "P. Christeas"
Дата:
Сообщение: Re: How do I use parameterized queries with LIKE?