Spring與JDBC的整合過程
原理:將DataSource傳給JdbcTemplate。
1. 導入數據庫連接池的jar包和連接數據庫的驅動包(這裏使用的dbcp數據庫連接池)
配置文件中注入dataSource
<?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.5.xsd"> <!-- 配置dbcp的數據庫連接池 --> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> <property name="driverClassName" value="oracle.jdbc.OracleDriver"></property> <property name="url" value="jdbc:oracle:thin:@localhost:1521:xe"></property> <property name="username" value="scott"></property> <property name="password" value="tiger"></property> </bean> </beans>
- 使用spring提供的JdbcTamplate類與spring進行整合。(整合方式有多種)
實現思路就是用多種方式注入JdbcTemplate
- 繼承JDBCSupport,注入JdbcTemplate
XMl文件
<bean id="personDao" class="com.lzl.spring.jdbc.dao.impl.PersonDaoImpl">
<property name="dataSource">
<ref bean="dataSource"/>
</property>
</bean>
Java類
public class PersonDaoImpl extends JdbcDaoSupport implements PersonDao{
@Override
public void savePerson() {
/**
* "insert into emp(empno,ename,empjob,sal,deptno) values(123920,'lzlh','programmer',10000,20)"
*/
this.getJdbcTemplate().execute("insert into emp(empno,ename,empjob,sal,deptno) values(1111,'lzlh','programmer',10000,20)");
}
}
- 在Dao層使用set/get方法注入JdbcTemplate類
Xml文件
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource">
<ref bean="dataSource"/>
</property>
</bean>
<bean id="personDao1" class="com.lzl.spring.jdbc.dao.impl.PersonDaoImpl1">
<property name="jdbcTemplate">
<ref bean="jdbcTemplate"/>
</property>
</bean>
Java文件
public class PersonDaoImpl1 implements PersonDao{
private JdbcTemplate jdbcTemplate;
public JdbcTemplate getJdbcTemplate() {
return jdbcTemplate;
}
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
@Override
public void savePerson() {
/**
* "insert into emp(empno,ename,empjob,sal,deptno) values(123920,'lzlh','programmer',10000,20)"
*/
this.getJdbcTemplate().execute("insert into emp(empno,ename,empjob,sal,deptno) values(122,'lzlh','programm',10000,10)");
}
}
3.繼承JdbcTemplate類,使用構造方法進行注入
Xml文件
<bean id="personDao2" class="com.lzl.spring.jdbc.dao.impl.PersonDaoImpl2">
<constructor-arg index="0" ref="dataSource"></constructor-arg>
</bean>
Java文件
public class PersonDaoImpl2 extends JdbcTemplate implements PersonDao{
public PersonDaoImpl2(DataSource dataSource) {
super(dataSource);
}
@Override
public void savePerson() {
this.execute("insert into emp(empno,ename,empjob,sal,deptno) values(883,'lzlh','programm',10000,10)");
}
}
JdbcTemplate的查詢
實現RowMapper接口
public class EmpRowMapping implements RowMapper<Emp>{ @Override public Emp mapRow(ResultSet rs, int rowNum) throws SQLException { rs =null; if(rs==null){ //這裏得判斷空 throw new IllegalAnnotationException("結果集不能爲空!"); } @SuppressWarnings("unused") Emp emp = new Emp(); emp.setEmpno(rs.getLong("empno")); emp.setEname(rs.getString("ename")); emp.setEmpJob(rs.getString("empjob")); emp.setSal(rs.getBigDecimal("sal")); emp.setDeptNo(rs.getLong("deptno")); System.out.println("==="+rowNum); return emp; } }
調用JdbcTemplate的query方法
@Override public List<Emp> queryEmp() { List<Emp> list = this.query("select empno,ename,empjob,sal,deptno from emp", new EmpRowMapping()); return list; }
Spring的聲明式事務管理
主要是在spring中配置關於事務的類。
事務管理配置過程
1. 數據庫配置,配置數據庫連接池(c3p0或者dbpc)
2. AOP配置,配置pointCut(切入點)和advisor通知。引入事務管理類(TransactionManager)
3. 事務配置,引入TransactionManager類,並注入DataSource類。
4. 事務方法管理, 聲明目標方法中那些方法需要事務,那些不需要,以及處理機制
Xml文件
<?xml version="1.0" encoding="UTF-8"?>
<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:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">
<!--
配置dbcp的數據庫連接池
-->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="oracle.jdbc.OracleDriver"></property>
<property name="url" value="jdbc:oracle:thin:@localhost:1521:xe"></property>
<property name="username" value="scott"></property>
<property name="password" value="tiger"></property>
</bean>
<!-- spring事務管理 -->
<!-- 引入事務管理類 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource">
<ref bean="dataSource"/>
</property>
</bean>
<!-- 聲明目標方法中那些方法需要事務,那些不需要 -->
<tx:advice id="tx" transaction-manager="transactionManager">
<tx:attributes>
<!--
name限定方法的名稱
isolation 隔離機制
propagation 傳播機制
read-only 只讀
-->
<tx:method name="save*" isolation="DEFAULT"
propagation="REQUIRED" read-only="false"/>
</tx:attributes>
</tx:advice>
<!-- 設置事務切面 -->
<aop:config>
<!--設置切入點 -->
<aop:pointcut expression="execution(* com.lzl.spring.jdbc.dao.impl.transaction.EmpDaoImpl.*(..))" id="perform"/>
<!-- 引入通知 -->
<aop:advisor advice-ref="tx" pointcut-ref="perform"/>
</aop:config>
<!-- 引入bean -->
<bean id="empDao" class="com.lzl.spring.jdbc.dao.impl.transaction.EmpDaoImpl">
<property name="dataSource">
<ref bean="dataSource"/>
</property>
</bean>
</beans>