spring_day04(JDBCTemplate实现CRUD,spring中的事务控制)

一.JDBCTemplat实现增删改查

1.jar包

 spring-jdbc-5.0.2.RELEASE.jar

 spring-tx-5.0.2.RELEASE.jar(它是和事务相关的)

2.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" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

 3.配置数据源

*c3po

*DBCP

*spring内置数据源

<bean id="dataSource"
      class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
    <property name="url" value="jdbc:mysql:///spring_day02"></property>
    <property name="username" value="root"></property>
    <property name="password" value="1234"></property>
</bean> 

 jdbc.driverClass=com.mysql.jdbc.Driver

jdbc.url=jdbc:mysql:///spring_day02

jdbc.username=root

jdbc.password=123

<!-- 引入外部属性文件: -->
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  
    <property name="location" value="classpath:jdbc.properties"/>
</bean> 

 4.配置JDBCTemplate

<!-- 配置一个数据库的操作模板:JdbcTemplate -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    <property name="dataSource" ref="dataSource"></property>
</bean> 

 5.在dao实现类中写业务代码,并实现IOC

两种方法:

*第一种在 Dao类中定义 JdbcTemplate 的方式,适用于所有配置方式(xml和注解都可以)。 在dao实现类中定义jdbctemplate,并生成set()方法,来实现jdbctemplate注入

*第二种让 Dao继承 JdbcDaoSupport 的方式,只能用于基于 XML 的方式,注解用不了(没办法改jdbcDaoSupport类源码)。 jabdDaoSupport是spring中自定义的一个类,有setJdbcTemplate()方法,dao实现类通过继承该类,从而拥有该方法,不用显式声明,也可以实现DI

二.spring中的事务控制

1.两种方式:

*基于配置的事物控制

*基于编码的事务控制

*均基于AOP

2.PlatformTransactionManager接口:

三个方法

*void commit(TransactionStatus status);

*void rollback(TransactionStatus status);

*TransactionStatus getTransaction(TransactionDefinition definition);

3.接口的实现类

org.springframework.jdbc.datasource.DataSourceTransactionManager

4.TransactionDefinition:

五个方法

5.TransactionStatus

六个操作

三.基于 XML 的声明式事务控制(配置方式)

1.jar包

2.xml约束:aop,tx名称空间

3.

四.基于 注解 的声明式事务控制(配置方式)

猜你喜欢

转载自www.cnblogs.com/counter-biao/p/11614096.html