sql >> Databasteknik >  >> RDS >> Oracle

Ställa in sessionens tidszon med spring jdbc oracle

Det korrekta sättet är att använda DelegatingDataSource , hämta OracleConnection objekt från den ursprungliga datakällan och anrop OracleConnection.setSessionTimeZone() med lämplig parameter.

C3P0-koden ser ut så här:

private Object[] timeZoneArgs = new Object[] { "Europe/Berlin" };

@Override
public Connection getConnection() throws SQLException {
    Connection conn = super.getConnection();
    try {
        final Method setSessionTimeZoneMethod = OracleConnection.class.getMethod("setSessionTimeZone", String.class);
        final C3P0ProxyConnection castCon = (C3P0ProxyConnection) conn;
        castCon.rawConnectionOperation(setSessionTimeZoneMethod, C3P0ProxyConnection.RAW_CONNECTION, timeZoneArgs);
        return conn;
    } catch (Exception e) {
        log.error("setSessionTimeZone failed " + e.getMessage());
        return conn;
    }
}


  1. Hur kan jag korrekt använda ett PDO-objekt för en parameteriserad SELECT-fråga

  2. SEC_TO_TIME() Exempel – MySQL

  3. Oracle 11g - Unpivot

  4. Snabbt och smutsigt för loopar i det omedelbara fönstret