Re: Why is columnNames in Connection.prepareStatement(sql, columnNames[]) automatically quoted

From: Dave Cramer <pg(at)fastcrypt(dot)com>
To: Balázs Zsoldos <balazs(dot)zsoldos(at)everit(dot)biz>
Cc: List <pgsql-jdbc(at)postgresql(dot)org>
Subject: Re: Why is columnNames in Connection.prepareStatement(sql, columnNames[]) automatically quoted
Date: 2015-07-31 00:49:27
Message-ID: CADK3HHLzBE6PFXWTCyvL8=hh8HUmYk+k-Mn4dz7DBKK46c4F+A@mail.gmail.com
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-jdbc

Actually I think I understand your issue. How would you propose this would
work for people who actually have mixed case column names ??

Dave Cramer

dave.cramer(at)credativ(dot)ca
http://www.credativ.ca

On 30 July 2015 at 20:47, Dave Cramer <pg(at)fastcrypt(dot)com> wrote:

> Hi,
>
> Yes there is a chance to change the driver, but I need more info. What do
> you mean they are automatically quoted ???
>
> Dave Cramer
>
> dave.cramer(at)credativ(dot)ca
> http://www.credativ.ca
>
> On 30 July 2015 at 20:32, Balázs Zsoldos <balazs(dot)zsoldos(at)everit(dot)biz>
> wrote:
>
>> Hi,
>>
>> I would like to write database independent SQL statements. Everything
>> works well, until I call *Connection.prepareStatement(sql,
>> columnNames[])*.
>>
>> In the SQL statement nothing is quoted and it works well. I am wondering,
>> why the values in the columnNames are automatically quoted? Is it a bug or
>> a feature?
>>
>> More info:
>>
>> I create the fields and tables in DDL without quoting them. Table and
>> field names become upper or lower case based on the engine. E.g.: In case
>> of Oracle, they will have upper-case names, in PostgreSQL they will have
>> lower-case names.
>>
>> If I use Oracle, I must provide the *columnNames* parameter for the
>> mentioned function with upper-case letters otherwise it does not work (I
>> think that is a bug, too, but I guess it is harder to send a patch for
>> Oracle than PostgreSQL :-) ). If I use any other database engines (Derby,
>> SQLServer, Hsqldb) everything works well.
>>
>> If I use PostgreSQL, however, I must provide lower-case letters for the
>> parameter as it is quoted inside. I do not think it should be quoted. If
>> someone wants to quote those column names, it would be possible by
>> providing the Strings with quotes like *Connection.prepareStatement(sql,
>> "\"myCamelCaseColumnName\"");*
>>
>> Do you think there is any chance to change this in PostgreSQL JDBC driver
>> or shall I write separate code for Postgres?
>>
>> Regards,
>> *Balázs **Zsoldos*
>>
>>
>

In response to

Responses

Browse pgsql-jdbc by date

  From Date Subject
Next Message Balázs Zsoldos 2015-07-31 01:03:39 Re: Why is columnNames in Connection.prepareStatement(sql, columnNames[]) automatically quoted
Previous Message Dave Cramer 2015-07-31 00:47:14 Re: Why is columnNames in Connection.prepareStatement(sql, columnNames[]) automatically quoted