Re: the use of $$string$$

Поиск
Список
Период
Сортировка
От Richard Huxton
Тема Re: the use of $$string$$
Дата
Msg-id 4EB79A86.1090005@archonet.com
обсуждение исходный текст
Ответ на Re: the use of $$string$$  (John Fabiani <johnf@jfcomputer.com>)
Ответы Re: the use of $$string$$  (Peter Eisentraut <peter_e@gmx.net>)
Список pgsql-sql
On 05/11/11 00:12, John Fabiani wrote:
> I'm using psycopg2.

OK - bear in mind, I'm not a Python user.

> This is what I'm doing from python
> myvarString = "long string that contains single quotes"
> cusor.execute("insert into table (pkid, myfield) values (%s, $$%s$$)",(123,
> myvarString))
>
> When I execute the above I'm seeing:
> E'long string that contains single quotes' in the field.  When I do a "select
> * from table"   I get E'long string that contains single quotes'.

OK, so it seems psycopg is quoting your strings for you (as you'd 
expect). It's presumably turning your query into:    ... values (E'123', $$E'<long string>'$$)
So - the $$ quoting is unnecessary here - just use the % placeholders.

Incidentally, should it be %s for the numeric argument?

> myvarString = "long string that without single quotes"
> cusor.execute("insert into table (pkid, myfield) values (%s, %s)",(123,
> myvarString))
>
> I get the following:
>   "long string that without single quotes"

That seems sensible to me (unless there's a typo in your example). You 
shouldn't need to quote any of your values in your Python code - it's 
doing it for you. I'm guessing there are other options beside %s for 
other data-types (integers,floats,boolean etc).

--   Richard Huxton  Archonet Ltd


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

Предыдущее
От: Samuel Gendler
Дата:
Сообщение: Re: Problem with pivot tables
Следующее
От: Olgierd Michalak
Дата:
Сообщение: Re: How to implement Aggregate Awareness?