Spring JdbcTemplate alter session(Spring JdbcTemplate更改会话)
本文介绍了Spring JdbcTemplate更改会话的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我要为从连接池获得的每个连接更改Oracle会话。
我发现只需执行一条语句就可以完成。请参阅here。
是否有办法挂钩到JDBC模板或数据源,并在连接池创建新连接后执行语句。
我正在使用Spring Boot并以这种方式创建数据源:
@Bean
@ConfigurationProperties(prefix="datasource.local")
public DataSource localDataSource() {
return DataSourceBuilder.create().build();
}
推荐答案
有很多方法可以做到这一点。 第一个:
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--只需提供一个建议,即在创建Get Connection之后,将在那里运行并执行您需要的任何操作。基本上它是相同的代理,但由Spring自动创建。
这篇关于Spring JdbcTemplate更改会话的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:Spring JdbcTemplate更改会话


基础教程推荐
猜你喜欢
- 如何使用 Eclipse 检查调试符号状态? 2022-01-01
- 如何对 HashSet 进行排序? 2022-01-01
- Java 中保存最后 N 个元素的大小受限队列 2022-01-01
- 如何在不安装整个 WTP 包的情况下将 Tomcat 8 添加到 Eclipse Kepler 2022-01-01
- 如何强制对超级方法进行多态调用? 2022-01-01
- 如何使用 Stream 在集合中拆分奇数和偶数以及两者的总和 2022-01-01
- 在螺旋中写一个字符串 2022-01-01
- 首次使用 Hadoop,MapReduce Job 不运行 Reduce Phase 2022-01-01
- 由于对所需库 rt.jar 的限制,对类的访问限制? 2022-01-01
- Spring Boot Freemarker从2.2.0升级失败 2022-01-01