spring项目中使用alibaba.druid.pool.DruidDataSource来装载oracle数据源
时间: 2023-12-16 13:48:37 浏览: 86
在Spring项目中使用阿里巴巴的Druid连接池来装载Oracle数据源,可以按照以下步骤进行:
1. 首先,在pom.xml文件中添加Druid和Oracle驱动的依赖:
```
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.6</version>
</dependency>
<dependency>
<groupId>com.oracle.jdbc</groupId>
<artifactId>ojdbc8</artifactId>
<version>19.7.0.0</version>
</dependency>
```
2. 在Spring配置文件中配置数据源:
```
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"/>
<property name="url" value="jdbc:oracle:thin:@localhost:1521:ORCL"/>
<property name="username" value="your_username"/>
<property name="password" value="your_password"/>
<property name="initialSize" value="5"/>
<property name="maxActive" value="50"/>
<property name="minIdle" value="5"/>
<property name="maxWait" value="60000"/>
<property name="validationQuery" value="SELECT 1 FROM DUAL"/>
<property name="testWhileIdle" value="true"/>
<property name="timeBetweenEvictionRunsMillis" value="60000"/>
<property name="minEvictableIdleTimeMillis" value="300000"/>
<property name="poolPreparedStatements" value="true"/>
<property name="maxPoolPreparedStatementPerConnectionSize" value="20"/>
</bean>
```
其中,initialSize是连接池启动时创建的初始化连接数;maxActive是连接池最大连接数;minIdle是连接池最小连接数;maxWait是获取连接的最大等待时间;validationQuery是用来检测连接是否有效的SQL语句;testWhileIdle是空闲时是否进行连接检测;timeBetweenEvictionRunsMillis是定时检查连接池中空闲连接的间隔时间;minEvictableIdleTimeMillis是连接池中连接最小空闲时间;poolPreparedStatements是是否缓存PreparedStatement;maxPoolPreparedStatementPerConnectionSize是单个连接池中最大的缓存Statement数目。
3. 在DAO层中使用该数据源:
```
@Repository
public class UserDaoImpl implements UserDao {
@Autowired
private DataSource dataSource;
private JdbcTemplate jdbcTemplate;
@PostConstruct
public void init() {
jdbcTemplate = new JdbcTemplate(dataSource);
}
// ...
}
```
在DAO实现类中通过@Autowired注入Druid数据源,并在@PostConstruct注解的init()方法中创建JdbcTemplate对象,即可使用该数据源进行数据库操作。
阅读全文