- Архив списков рассылки pgsql-interfaces

Поиск
Список
Период
Сортировка
От Darko Prenosil
Тема
Дата
Msg-id 007e01c14c2e$d1e69240$ef00000a@darko
обсуждение исходный текст
Ответы Re:  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-interfaces
Hi guys,
Sorry for bothering you, but we ran into a situation...
Story goes like this:
We wanted to use non-blocking PQSendQuery to send a large query which consists of many SELECTs. Our pglib interface sent just first 8192 bytes and returned EOF. Whole query was more than 64k.
 
We took a brief look through the source and here is what confuses us:
 
These two chunks of code are from fe-misc.c
 
pqPutBytes(const char *s, size_t nbytes, PGconn *conn){
........
while (nbytes > avail)
 {
  memcpy(conn->outBuffer + conn->outCount, s, avail);
  conn->outCount += avail;
  s += avail;
  nbytes -= avail;
  if (pqFlush(conn))                       
   return EOF;
  avail = conn->outBufSize;
 }
...........
}
 
*************************************
pqFlush(PGconn *conn) {
............
#ifdef USE_SSL
   /* can't do anything for our SSL users yet */
   if (conn->ssl == NULL)
   {
#endif
    if (pqIsnonblocking(conn))
    {
     /* shift the contents of the buffer */
     memmove(conn->outBuffer, ptr, len);
     conn->outCount = len;
     return EOF;                                    <- Why it returns EOF after just shifting the buffer ???
    }
#ifdef USE_SSL
   }
#endif
...............
}
 
 
When we corected the code to look like this:
 
#ifdef USE_SSL
   /* can't do anything for our SSL users yet */
   if (conn->ssl == NULL)
   {
    if (pqIsnonblocking(conn))
    {
     /* shift the contents of the buffer */
     memmove(conn->outBuffer, ptr, len);
     conn->outCount = len;
     return EOF;                                   
    }
   }
#endif
 
we succeed to send queries bigger than 8k. We tried to figure what is happening, and saw that there
is few pqWait calls, but our queries are send correctly. Is there some fact that we are missing ?
Can You please explain ???
Maybe it is important to say that we are compiling library for WIN32.
 
 
Thanks.
Darko
 

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

Предыдущее
От: Dave Page
Дата:
Сообщение: Re: select in a LIKE?
Следующее
От: Tom Lane
Дата:
Сообщение: Re: