我想改变从连接池获得的每个连接的Oracle会话。
我发现只需执行一个语句就可以完成。请参阅here。
有没有办法挂钩到jdbc模板或数据源,并在连接池创建新连接后执行语句。
我使用Spring Boot并以这种方式创建数据源:
@Bean
@ConfigurationProperties(prefix="datasource.local")
public DataSource localDataSource() {
return DataSourceBuilder.create().build();
}
答案 0 :(得分:2)
有很多方法可以做到这一点。 第一个:
DataSource是一个界面,为什么不自己实现它(使用代理模式)?创建这样的东西:
class MyDataSource implements DataSource {
private DataSource realDataSource;
public Connection getConnection() {
Connection c = realDataSource.getConnection();
// do whatever you want to do and
return c;
}
}
所有其他方法将直接委托给realDataSource。
此代理可用于提供的代码段。
您可以使用一些AOP - 只需提供一条建议,即在创建连接后将运行并执行您需要的任何操作。基本上它是相同的代理,但是由Spring自动创建。