Re: BUG #2189: Prepared Statement is not parsed correctly

From: Bruce Momjian <pgman(at)candle(dot)pha(dot)pa(dot)us>
To: Kris Senden <kris(dot)senden(at)realsoftware(dot)be>
Cc: pgsql-bugs(at)postgresql(dot)org
Subject: Re: BUG #2189: Prepared Statement is not parsed correctly
Date: 2006-01-22 02:44:11
Message-ID: 200601220244.k0M2iBm07507@candle.pha.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs


This is not the place to report jdbc problems. The jdbc project has its
own mailing lists.

---------------------------------------------------------------------------

Kris Senden wrote:
>
> The following bug has been logged online:
>
> Bug reference: 2189
> Logged by: Kris Senden
> Email address: kris(dot)senden(at)realsoftware(dot)be
> PostgreSQL version: 8.0.2
> Operating system: Windows XP/2K/2003
> Description: Prepared Statement is not parsed correctly
> Details:
>
> Recently we discovered a defect in the jdbc driver of PostgreSQL. It is
> detected in version 8.1dev-401 and also found in all later versions. The
> problem is that we had a faulty SQL statement in our code that was partly
> executed by the jdbc-driver without any warning or error log.
> The statement is SELECT * FROM POSTransaction WHERE DatTransEnd = (SELECT
> MAX(DatTransEnd) FROM POSTransaction WHERE IdtCheckout = 9 AND FlgTraining =
> ?) AND IdtCheckout = 9 AND FlgTraining = ?) ORDER BY HouTransEnd DESC. As
> you can see this statement contains 1 closing bracket ('(') too much.
> However while debugging the driver I saw that the problem is caused in
> method AbstractJdbc2Statement.parseSql(String, int, StringBuffer, boolean)
> throws SQLException. In that method a counter is activated which holds the
> number of open brackets. Each time it encounters a ( it adds one and each
> time it encounters a ) it substracts one. When the counter's value is less
> than zero, the parsings stops.
> In our case, this resulted that our sql statement was shortened to SELECT *
> FROM POSTransaction WHERE DatTransEnd = (SELECT MAX(DatTransEnd) FROM
> POSTransaction WHERE IdtCheckout = 9 AND FlgTraining = ?) AND IdtCheckout =
> 9 AND FlgTraining = ?
> When executing the same query in pgAdmin III Query, I got a syntax error :
> ERROR: syntax error at or near ")" at character 136. I would expected to
> have the same syntax error using the prepared statement.
>
> ---------------------------(end of broadcast)---------------------------
> TIP 1: if posting/reading through Usenet, please send an appropriate
> subscribe-nomail command to majordomo(at)postgresql(dot)org so that your
> message can get through to the mailing list cleanly
>

--
Bruce Momjian | http://candle.pha.pa.us
pgman(at)candle(dot)pha(dot)pa(dot)us | (610) 359-1001
+ If your life is a hard drive, | 13 Roberts Road
+ Christ can be your backup. | Newtown Square, Pennsylvania 19073

In response to

Browse pgsql-bugs by date

  From Date Subject
Next Message Bruce Momjian 2006-01-22 02:44:49 Re: BUG #2190: ODBC SQLPrimaryKeys PK_NAME missing info
Previous Message Tom Lane 2006-01-21 18:23:47 Re: BUG #2195: log_min_messages crash server when in DEBUG3 to 5