Skip site navigation (1) Skip section navigation (2)

Re: 7.1 beta 3 Linux ODBC BEGIN Behaviour

From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
To: "Hiroshi Inoue" <Inoue(at)tpf(dot)co(dot)jp>
Cc: "Hiroki Kataoka" <kataoka(at)interwiz(dot)koganei(dot)tokyo(dot)jp>, pgsql-interfaces(at)postgresql(dot)org, pgsql-odbc(at)postgresql(dot)org, "Steve Wranovsky" <stevew(at)merge(dot)com>
Subject: Re: 7.1 beta 3 Linux ODBC BEGIN Behaviour
Date: 2001-02-10 17:30:45
Message-ID: (view raw, whole thread or download thread mbox)
Lists: pgsql-interfacespgsql-odbc
"Hiroshi Inoue" <Inoue(at)tpf(dot)co(dot)jp> writes:
>> There must be "SELECT ~ FOR UPDATE" of inside of the transaction.

> You are right.
> However psqlodbc has never checked "for update".
> My recent change doesn't take "for update" into
> account either. 

It'd be nice if ODBC could distinguish SELECT FOR UPDATE from plain
SELECT, but in practice it cannot reliably do so.  Doubtless we could
extend ODBC to look for "FOR UPDATE" in the text of the query, but
that will only catch simple situations.  Consider these possibilities:

* A view or rule invoked by the query uses FOR UPDATE.  (Pre-7.1, we
didn't support FOR UPDATE in views ... but we do now.)

* A function invoked by the query does SELECT FOR UPDATE internally.

For that matter, it's quite possible for a function invoked by a SELECT
to do INSERT/UPDATE/DELETE internally.  Therefore, it's impossible for
the ODBC driver to reliably distinguish a pure SELECT from a SELECT that
causes locking or even data updates.

Given these considerations, I think it's a mistake for ODBC to treat
SELECT differently from other queries for the purpose of setting
transaction boundaries.

			regards, tom lane

In response to


pgsql-odbc by date

Next:From: Peter EisentrautDate: 2001-02-10 18:09:23
Subject: Re: Re: [PATCHES] Fix for ODBC close
Previous:From: Bruce MomjianDate: 2001-02-10 17:17:13
Subject: Re: Re: [PATCHES] Fix for ODBC close

pgsql-interfaces by date

Next:From: László TiborDate: 2001-02-10 18:15:56
Subject: RE: [INTERFACES] 7.1 beta 3 Linux ODBC BEGIN Behaviour
Previous:From: Hiroshi InoueDate: 2001-02-10 14:22:19
Subject: RE: 7.1 beta 3 Linux ODBC BEGIN Behaviour

Privacy Policy | About PostgreSQL
Copyright © 1996-2017 The PostgreSQL Global Development Group