<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName">
<value>oracle.jdbc.driver.OracleDriver</value>
</property>
<property name="url">
<value>jdbc:oracle:thin:@10.10.3.237:1521:tarena</value>
</property>
<property name="username">
<value>openlab</value>
</property>
<property name="password">
<value>open123</value>
</property>
</bean>
<bean id="mySessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="mappingResources">
<list>
<value>domain/User.hbm.xml</value>
<value>domain/ServiceAccount.hbm.xml</value>
<value>domain/Pricing.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.Oracle9Dialect
</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
</bean>
<bean id="userDao" class="dao.UserDaoHibernateImpl">
<property name="sessionFactory">
<ref local="mySessionFactory" />
</property>
</bean>
<bean id="myTransactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory">
<ref bean="mySessionFactory" />
</property>
</bean>
<bean id="userServiceTarget"
class="service.UserServiceSpringImpl">
<property name="userDao">
<ref local="userDao" />
</property>
</bean>
<bean id="userService"
class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="proxyInterfaces">
<value>service.UserService</value>
</property>
<property name="transactionManager">
<ref bean="myTransactionManager" />
</property>
<property name="target">
<ref bean="userServiceTarget" />
</property>
<property name="transactionAttributes">
<props>
<prop key="*">PROPAGATION_REQUIRED</prop>
</props>
</property>
</bean>
<bean name="LoginAction" class="actions.LoginAction">
</bean>
<bean name="BillDetailQueryAction" class="actions.BillDetailQueryAction">
<property name="userService">
<ref local="userService" />
</property>
</bean>
<bean name="DefaultBillQueryAction" class="actions.DefaultBillQueryAction">
<property name="userService">
<ref local="userService" />
</property>
</bean>
<bean name="ModifyUserAction" class="actions.ModifyUserAction">
<property name="userService">
<ref local="userService" />
</property>
</bean>
<bean name="SpecifiedAccountBillQueryAction" class="actions.SpecifiedAccountBillQueryAction">
<property name="userService">
<ref local="userService" />
</property>
</bean>
<bean name="SpecifiedBillQueryAction" class="actions.SpecifiedBillQueryAction">
<property name="userService">
<ref local="userService" />
</property>
</bean>
</beans>
《Spring的数据源配置文件模板》applicationContext.zip



在Spring框架中,数据源(DataSource)是连接数据库的关键组件,它是应用程序与数据库交互的桥梁。`applicationContext.xml`是Spring应用上下文配置文件,通常用于定义bean的声明、依赖注入以及数据源的相关配置。本文件模板将详细介绍如何在Spring中配置数据源,以便为你的应用程序提供稳定、高效的数据库连接。 我们需要理解Spring支持多种类型的数据源,包括Apache的DBCP、C3P0、HikariCP以及Oracle的UCP等。选择哪种数据源取决于你的项目需求,例如性能、稳定性和资源管理等因素。这里我们以常用的HikariCP为例进行配置。 1. 引入依赖: 在你的`pom.xml`或`build.gradle`文件中,添加HikariCP的依赖。对于Maven用户,可以添加如下代码: ```xml <dependency> <groupId>com.zaxxer</groupId> <artifactId>HikariCP</artifactId> <version>版本号</version> </dependency> ``` 2. 配置数据源: 在`applicationContext.xml`文件中,使用`<bean>`标签定义数据源bean。HikariCP的数据源配置类为`com.zaxxer.hikari.HikariConfig`,而数据源实例为`com.zaxxer.hikari.HikariDataSource`。下面是一个示例配置: ```xml <bean id="dataSource" class="com.zaxxer.hikari.HikariDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"/> <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/mydb"/> <property name="username" value="root"/> <property name="password" value="password"/> <!-- HikariCP特定配置 --> <property name="poolName" value="SpringHikariCP"/> <property name="maximumPoolSize" value="10"/> <property name="idleTimeout" value="30000"/> <property name="connectionTimeout" value="20000"/> <property name="leakDetectionThreshold" value="30000"/> </bean> ``` 这里配置了数据库驱动、URL、用户名、密码,以及HikariCP的一些关键参数,如最大连接池大小、空闲超时时间、连接超时时间以及泄漏检测阈值。 3. 配置JdbcTemplate或JPA: Spring提供了`JdbcTemplate`和`JPA`两种方式来操作数据库。如果你选择`JdbcTemplate`,你需要定义一个`JdbcTemplate`的bean,并注入之前创建的数据源: ```xml <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"> <property name="dataSource" ref="dataSource"/> </bean> ``` 如果你选择JPA,你需要配置`LocalContainerEntityManagerFactoryBean`,并指定数据源、实体扫描路径等: ```xml <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="packagesToScan" value="com.example.entity"/> <property name="jpaVendorAdapter"> <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> <property name="showSql" value="true"/> </bean> </property> <property name="jpaProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop> <!-- 其他Hibernate配置 --> </props> </property> </bean> ``` 4. 使用事务管理器: 为了确保数据库操作的原子性和一致性,我们需要配置事务管理器。对于JDBC,我们可以使用`PlatformTransactionManager`的实现`DataSourceTransactionManager`: ```xml <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> ``` 对于JPA,我们可以使用`JpaTransactionManager`: ```xml <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> <property name="entityManagerFactory" ref="entityManagerFactory"/> </bean> ``` 以上就是Spring中配置数据源的基本步骤,通过`applicationContext.xml`文件,你可以根据项目需求灵活调整数据源配置,确保数据库连接的高效和稳定。在实际开发中,你可能还需要考虑更多因素,比如数据库连接池的优化、事务管理策略以及异常处理机制等。


- 1




















- 粉丝: 1
- 资源: 7
我的内容管理 展开
我的资源 快来上传第一个资源
我的收益
登录查看自己的收益我的积分 登录查看自己的积分
我的C币 登录后查看C币余额
我的收藏
我的下载
下载帮助


最新资源
- 《你看起来好像……我爱你:AI的工作原理以及它为这个世界带来的稀奇古怪》.epub
- 函数式编程思维.epub
- win1124H2制作通用镜像
- 产品软件测试方案.pdf
- 渗透测试之信息收集思维导图
- Kubernetes集群部署指南:使用Kubeadm搭建与配置最新版k8s集群
- Delphi快速语法参考(Delphi 10.4 Sydney).pdf
- 川力WMS11111111
- HTML5核心技术详解与应用指南
- 基于铣削力预测模型的复杂曲面加工参数优化研究-Python实现与应用(复现论文,含详细可运行代码及解释)
- 内河通航密集区弯曲航段饱和度研究与仿真分析-基于Python的实现(复现论文,含详细可运行代码及解释)
- 欸发婚房能看到v看看vverve吕尔哥v
- python-test+test-tets-tets
- 思科模拟器用telnet、ssh远程登录交换机
- apache solr ssrf漏洞验证poc CVE-2021-27905
- Lightweight and Efficient: The backbone of the TTS Diffusion Transformer has only 0.45B param



评论2