Re: psycopg3 and adaptation choices

Поиск
Список
Период
Сортировка
От Federico Di Gregorio
Тема Re: psycopg3 and adaptation choices
Дата
Msg-id 1546497c-ff41-9bd0-b4d7-931bd305caac@dndg.it
обсуждение исходный текст
Ответ на Re: psycopg3 and adaptation choices  (Daniele Varrazzo <daniele.varrazzo@gmail.com>)
Ответы Re: psycopg3 and adaptation choices  (Vladimir Ryabtsev <greatvovan@gmail.com>)
Список psycopg
On 09/11/20 13:00, Daniele Varrazzo wrote:
> On Mon, 9 Nov 2020 at 06:57, Federico Di Gregorio <fog@dndg.it> wrote:
[snip]
>> IMHO, oid is a bad idea
>> because it has a very specific semantic and the error messages generated
>> by PostgreSQL will be more confusing.
> 
> I'm not sure I understand this. At the moment, the oids are something
> that don't really surface to the end-users, who are not required to
> use them explicitly and shouldn't be seen in the error messages. For
> instance the query above might results in a call:
> 
>      >>> from psycopg3.oids import builtins
>      >>> builtins["numeric"].oid
>      1700
> 
>      >>> res = conn.pgconn.exec_params(b"select '[]'::jsonb -> $1",
> [b"1"], [1700])
>      >>> res.status
>      <ExecStatus.FATAL_ERROR: 7>
> 
>      >>> print(res.error_message.decode("utf8"))
>      ERROR:  operator does not exist: jsonb -> numeric
>      LINE 1: select '[]'::jsonb -> $1
>                                ^
>      HINT:  No operator matches the given name and argument types. You
> might need to add explicit type casts.
> 
> So the oid is only used internally, in the mapping python type ->
> exec_params() types array, the 1700 shouldn't surface anywhere.
> 
> Maybe I'm misunderstanding your concern: can you tell me better?

My fault. I misread and though you wanted to use OID as *the* type to 
pass to PostggreSQL for numbers.

federico




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

Предыдущее
От: Daniele Varrazzo
Дата:
Сообщение: Re: psycopg3 and adaptation choices
Следующее
От: Vladimir Ryabtsev
Дата:
Сообщение: Re: psycopg3 and adaptation choices