Получить OracleDataSource в SpringBoot 2 - PullRequest
0 голосов
/ 09 апреля 2020

Можно ли получить OracleDataSource из пула соединений SpringBoot 2 Hikari по умолчанию, используя объект NamedParameterJdbcTemplate? Использование Java 8, Oracle 11g (ojdbc6-11.2.0.1.jar) и gradle Это то, что я пробовал.

@Repository
public class MyClass{

@Autowired
NamedParameterJdbcTemplate  jdbcTemplate;

public void myMethod(){
try{
    //OracleDataSource ods = new OracleDataSource();                                            // This works but is obviously not Spring
    OracleDataSource ods = (OracleDataSource) jdbcTemplate.getJdbcTemplate().getDataSource();   // This fails

    ods.setURL(url);
    ods.setUser(user);
    ods.setPassword(pass);

    ...
    catch(Exception e){
            System.out.println("In Exception");
            e.printStackTrace();
    }
}

}

Application.properties:

spring.datasource.url=jdbc:oracle:thin:@//${ORA_HOST}:${ORA_PORT}/${ORA_SID}
spring.datasource.username=${USER}
spring.datasource.password=${PASS}  

Сообщение об ошибке:

In Exception
java.lang.ClassCastException: com.zaxxer.hikari.HikariDataSource cannot be cast to oracle.jdbc.pool.OracleDataSource

1 Ответ

0 голосов
/ 14 апреля 2020

Я не думаю, что это возможно (или необходимо). Самый простой способ - развернуть () объект подключения, который уже подключен к дБ:

Connection conn =  this.jdbcTemplate.getJdbcTemplate().getDataSource().getConnection().unwrap(OracleConnection.class);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...