Spring與JDBC整合

Spring與JDBC的整合過程

原理:將DataSource傳給JdbcTemplate。
1. 導入數據庫連接池的jar包和連接數據庫的驅動包(這裏使用的dbcp數據庫連接池)

  1. 配置文件中注入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>
    
  2. 使用spring提供的JdbcTamplate類與spring進行整合。(整合方式有多種)
    實現思路就是用多種方式注入JdbcTemplate
  1. 繼承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)");
}
}
  1. 在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的查詢

  1. 實現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;
    }
    }
    
  2. 調用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>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章