spring数据源配置及事务管理--jdbc
2013-09-27 16:36
681 查看
两种数据源配置和两种事务管理
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">
<aop:config proxy-target-class="true"/><!-- cglib实现代理,不需要借口 -->
<bean id="dataSource_jdbc" class="org.springframework.jdbc.datasource.DriverManagerDataSource" >
<property name="url" value="jdbc:mysql://localhost:3306/ppt?useUnicode=true&characterEncoding=UTF-8"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</bean>
<bean id="dataSource_dbcp" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="password" value="root"/>
<property name="username" value="root"/>
<property name="url" value="jdbc:mysql://localhost:3306/ppt?useUnicode=true&characterEncoding=UTF-8"/>
<property name="maxActive" value="20"/>
<property name="maxIdle" value="15"/>
<property name="minIdle" value="5"/>
<property name="maxWait" value="60000"/>
<property name="initialSize" value="1"/>
<property name="removeAbandoned" value="true"/>
<property name="removeAbandonedTimeout" value="180"/>
<property name="logAbandoned" value="true"/>
<property name="timeBetweenEvictionRunsMillis" value="3600000"/>
<property name="minEvictableIdleTimeMillis" value="3600000"/>
<property name="defaultAutoCommit" value="false"/>
</bean>
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" >
<property name="dataSource">
<ref local="dataSource_dbcp"/>
</property>
</bean>
<bean id="jdbcDemo" class="com.csair.dao.JdbcDemo">
<property name="jdbcTemplate">
<ref local="jdbcTemplate"/>
</property>
</bean>
<!-- 事务管理 -->
<bean id="dataSourceTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource">
<ref local="dataSource_dbcp"/>
</property>
</bean>
<!-- 注解实现事务管理 -->
<!-- <tx:annotation-driven transaction-manager="dataSourceTransactionManager"/> -->
<!-- aop实现事务管理 -->
<aop:config>
<aop:pointcut expression="execution(* com.csair.dao.**.*(..))" id="pointCut"/>
<aop:advisor advice-ref="adive" pointcut-ref="pointCut"/>
</aop:config>
<tx:advice id="adive" transaction-manager="dataSourceTransactionManager">
<tx:attributes>
<tx:method name="insert*" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
</beans>
测试
package com.csair.dao;
import java.util.List;
import java.util.Map;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.transaction.annotation.Transactional;
@Transactional
public class JdbcDemo {
private JdbcTemplate jdbcTemplate;
public static void main(String[] args) {
String configLocation = "applicationContext-jdbc.xml";
ClassPathXmlApplicationContext contenxt = new ClassPathXmlApplicationContext(configLocation);
JdbcDemo demo = contenxt.getBean("jdbcDemo", JdbcDemo.class);
demo.insert();
demo.query();
}
public void query() {
String sql = "select * from user";
List<Map<String, Object>> list = jdbcTemplate.queryForList(sql);
System.out.println("Object: " + list.toString());
int count = jdbcTemplate.queryForInt("select count(*) from user");
System.out.print("count: " + count);
}
public void insert() {
String insert = "insert into user(username, password) values('okok','koko')";
jdbcTemplate.execute(insert);
}
public JdbcTemplate getJdbcTemplate() {
return jdbcTemplate;
}
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
}
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">
<aop:config proxy-target-class="true"/><!-- cglib实现代理,不需要借口 -->
<bean id="dataSource_jdbc" class="org.springframework.jdbc.datasource.DriverManagerDataSource" >
<property name="url" value="jdbc:mysql://localhost:3306/ppt?useUnicode=true&characterEncoding=UTF-8"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</bean>
<bean id="dataSource_dbcp" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="password" value="root"/>
<property name="username" value="root"/>
<property name="url" value="jdbc:mysql://localhost:3306/ppt?useUnicode=true&characterEncoding=UTF-8"/>
<property name="maxActive" value="20"/>
<property name="maxIdle" value="15"/>
<property name="minIdle" value="5"/>
<property name="maxWait" value="60000"/>
<property name="initialSize" value="1"/>
<property name="removeAbandoned" value="true"/>
<property name="removeAbandonedTimeout" value="180"/>
<property name="logAbandoned" value="true"/>
<property name="timeBetweenEvictionRunsMillis" value="3600000"/>
<property name="minEvictableIdleTimeMillis" value="3600000"/>
<property name="defaultAutoCommit" value="false"/>
</bean>
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" >
<property name="dataSource">
<ref local="dataSource_dbcp"/>
</property>
</bean>
<bean id="jdbcDemo" class="com.csair.dao.JdbcDemo">
<property name="jdbcTemplate">
<ref local="jdbcTemplate"/>
</property>
</bean>
<!-- 事务管理 -->
<bean id="dataSourceTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource">
<ref local="dataSource_dbcp"/>
</property>
</bean>
<!-- 注解实现事务管理 -->
<!-- <tx:annotation-driven transaction-manager="dataSourceTransactionManager"/> -->
<!-- aop实现事务管理 -->
<aop:config>
<aop:pointcut expression="execution(* com.csair.dao.**.*(..))" id="pointCut"/>
<aop:advisor advice-ref="adive" pointcut-ref="pointCut"/>
</aop:config>
<tx:advice id="adive" transaction-manager="dataSourceTransactionManager">
<tx:attributes>
<tx:method name="insert*" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
</beans>
测试
package com.csair.dao;
import java.util.List;
import java.util.Map;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.transaction.annotation.Transactional;
@Transactional
public class JdbcDemo {
private JdbcTemplate jdbcTemplate;
public static void main(String[] args) {
String configLocation = "applicationContext-jdbc.xml";
ClassPathXmlApplicationContext contenxt = new ClassPathXmlApplicationContext(configLocation);
JdbcDemo demo = contenxt.getBean("jdbcDemo", JdbcDemo.class);
demo.insert();
demo.query();
}
public void query() {
String sql = "select * from user";
List<Map<String, Object>> list = jdbcTemplate.queryForList(sql);
System.out.println("Object: " + list.toString());
int count = jdbcTemplate.queryForInt("select count(*) from user");
System.out.print("count: " + count);
}
public void insert() {
String insert = "insert into user(username, password) values('okok','koko')";
jdbcTemplate.execute(insert);
}
public JdbcTemplate getJdbcTemplate() {
return jdbcTemplate;
}
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
}
相关文章推荐
- ServletContext 通过servlet filter listner struts2四种方式获取
- spring的ioc原理(java反射机制)
- Sizing the Java heap
- Java语言程序设计-基础篇第二章基本程序设计
- java--堆栈
- java正则表达式
- java.util.Date和java.sql.Date的区别及应用
- Struts2与Hibernate简易分页Demo(待完善)
- 泛型和可变长参数
- json字符串,json对象,java对象之间的那点事……
- 第一章~第一节spring bean的生命周期
- JVM调优:对eclipse启动调优纪实(1)
- 【Struts2实现单文件上传】
- BOS集成开发环境下反编译
- [mess]java基础1234
- java IO【转】
- 用注解的方式来实现SPIRNG视图转换
- java eclipse 注释代码快捷键 取消代码注释快捷键
- Java中对于回调函数的简单理解
- jboss下部署配置spring jndi