Re: Getting oid with libpq

Поиск
Список
Период
Сортировка
От jtv@xs4all.nl
Тема Re: Getting oid with libpq
Дата
Msg-id 10445.202.47.227.25.1123671132.squirrel@202.47.227.25
обсуждение исходный текст
Ответ на Getting oid with libpq  ("Johan C. de Koning" <johan.de.koning@geodan.nl>)
Ответы Re: Getting oid with libpq
Список pgsql-interfaces
Johan C. de Koning wrote:

> I have stored some large objects (which are images) with the lo_import
> function. Now I can read the images with the other functions like lo_read
> within libpq. But I have one problem with the oid I have to give to this
> method. Inside my program I will do a select like this

> Select texture from building_face where face_id > 100;

> Textures is the oid field. When I use PQgetValue() I get a complete
> different value then when I do  a select inside pgAdmin. How can I get the
> same oid so that I can use this for reading the data of the images inside
> my c++ program. Because it is not working with the oid from PQgetValue.

Just a guess, but...

One mistake many people make is to cast the char * returned by
PQgetValue() to the type they expect to get.  Which won't work, since it's
a pointer to a value (in this case a number) in a textual format.  It
needs to be parsed so you get the actual numeric value.

Also, when you parse the number, be aware that the standard-library
functions (such as sscanf()) take the applicable locale setting into
account--which is not what you want in this case.  Best reset to the
default locale before parsing.


Jeroen




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

Предыдущее
От: jasiek@klaster.net
Дата:
Сообщение: cancel
Следующее
От: "Johan C. de Koning"
Дата:
Сообщение: Re: Getting oid with libpq