transactions in libpq++ require new connection?

Поиск
Список
Период
Сортировка
От George Young
Тема transactions in libpq++ require new connection?
Дата
Msg-id 199907081955.PAA21607@ll.mit.edu
обсуждение исходный текст
Ответы Re: [INTERFACES] transactions in libpq++ require new connection?  (Tom Lane <tgl@sss.pgh.pa.us>)
Re: [INTERFACES] transactions in libpq++ require new connection?  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-interfaces
I am using libpq++ with gcc egcs-2.91.66 (egcs-1.1.2 release) on RH linux 5.1
with Postgres 6.5.  I need to use transactions to maintain consistency
when an application's logical operation actually updates multiple tables.

Currently, the PgTransaction class only has a public constructor which
opens a new connection to the DB, and closes it on commit.  For an application
making many short transactions, in an environment with many active clients,
this seems to be very wasteful of network and cpu resources.  Is there some
reason a PgTransaction could not be constructed from an existing PgDatabase
(or PgConnection)?  Maybe trans should be a lightweight class to avoid
problems with inheriting from PgDatabase and thus having to deal with 
copy/reference-count etc. problems?

I know I can roll my own by just Exec("begin"), etc, but having the
transaction *committed* (not conn closed) in the destructor would be very
handy.


Also, there's no rollback member...


On yet another note, it would be much neater if the c++ interface would use
'string' type for text args and returns.  I'm tired of writing foo.c_str()
everywhere...


Thanks,George

[I'm not too experienced with c++, so I *welcome* any comments/suggestions]


George Young,  Rm. L-204        gry@ll.mit.edu
MIT Lincoln Laboratory
244 Wood St.
Lexington, Massachusetts  02420-9108    (781) 981-2756


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

Предыдущее
От: "C.J. Pena"
Дата:
Сообщение: No suitable driver
Следующее
От: Florian Baumert
Дата:
Сообщение: Postgresql + lo