From: | Laurenz Albe <laurenz(dot)albe(at)cybertec(dot)at> |
---|---|
To: | Manav Kumar <mkumar(at)yugabyte(dot)com>, pgsql-bugs(at)lists(dot)postgresql(dot)org |
Subject: | Re: Understanding JDBC Behaviour |
Date: | 2025-05-19 07:15:56 |
Message-ID: | 21e42f9bc769d8b863ce660c508c6a50930a504c.camel@cybertec.at |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-bugs |
On Sat, 2025-05-17 at 18:05 +0530, Manav Kumar wrote:
> I'm writing to clarify a syntax to pass the guc options in the startup packt of the connection via JDBC.
>
>
> Wrote below small java program:
>
> Properties props = new Properties();
> props.setProperty("options", "-c DateStyle=Postgres,DMY");
> props.setProperty("user", "postgres");
> props.setProperty("password", "postgres");
> connection = DriverManager.getConnection(
> "jdbc:postgresql://localhost:5432/postgres", props);
>
> stmt1 = connection.createStatement();
> ResultSet rs = stmt1.executeQuery("show DateStyle");
> while (rs.next()) {
> System.out.println(rs.getString(1));
> }
> stmt1.execute("reset DateStyle");
> rs = stmt1.executeQuery("show DateStyle");
> while (rs.next()) {
> System.out.println(rs.getString(1));
> }
>
> The output I'm getting is:
> ISO, DMY
> ISO, DMY.
>
> Rather shouldn't the expected output should be
> Postgres, DMY
> Postgres, DMY //Please correct me - Even after the reset the default value should be Postgres, DMY ?
> I checked the official docs, and found the syntax above.
> Looking forward to seeing your response! Please let me know if I should post elsewhere.
The correct list would have been pgsql-jdbc, but I'll answer here.
There is no bug involved. The behavior can be explained as follows:
1. The PostgreSQL JDBC driver forces "DateStyle" to "ISO", because it needs that setting
to handle dates and timestamps correctly. If you manage to change the setting, the
driver will fail with the error message:
The server''s DateStyle parameter was changed to ....
The JDBC driver requires DateStyle to beegin with ISO for correct operation.
2. RESET will reset the parameter to what it was when the session started.
Yours,
Laurenz Albe
From | Date | Subject | |
---|---|---|---|
Next Message | Stepan Neretin | 2025-05-19 07:24:47 | Re: BUG #18923: pg_dump 18beta1 fails to process complex table names |
Previous Message | Ge Yuxiang | 2025-05-19 05:03:02 | Ge Yuxiang added you to the postgresql group |