五.Spring-jdbc的实现

第一步:导jar包 pom.xml

<!--引入spring-beans节点-->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-beans</artifactId>
    <version>4.2.3.RELEASE</version>
</dependency>
<!--引入Spring-context节点-->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>4.2.2.RELEASE</version>
</dependency>

<!--引入Spring-JDBC节点-->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-jdbc</artifactId>
    <version>4.2.0.RELEASE</version>
</dependency>

<dependency>
    <groupId>org.wisdom-framework</groupId>
    <artifactId>MySQL-connector-Java</artifactId>
    <version>5.1.34_1</version>
</dependency>

第二步:实体层

public class User {
    private Integer bookid;
    private String bookname;
    private Integer bookprice;

public Integer getBookid() {
        return bookid;
    }

public void setBookid(Integer bookid) {
        this.bookid= bookid;
    }

public String getBookname() {
        return bookname;
    }

public void setBookname(String bookname) {
        this.bookname= bookname;
    }

public Integer getBookprice() {
        return bookprice;
    }

public void setBookprice(Integer bookprice) {
        this.bookprice= bookprice;
    }
}

第三步:搭建分层

A:dao层

接口:
//01.查询素有图书
public List<User> findAll();

接口实现:需要实现接口,继承JdbcDaoSupport 植入jdbcTemplate:简化jdbc操作

public class userdaoimpextends JdbcDaoSupport implements userdao {
    // 需要植入   jdbcTemplate
    
publicList<User> findAll() {
        String sql="select * from book";
        //接口的一个实现类 匿名内部类
        
List<User> list=this.getJdbcTemplate().query(sql,new RowMapper<User>() {
            public User mapRow(ResultSet rs,int i) throwsSQLException {
                User book=new User();
                book.setBookid(rs.getInt("bookid"));
                book.setBookname(rs.getString("bookname"));
                book.setBookprice(rs.getInt("bookprice"));
                return book;
            }
        });
        return list;
    }
    }

第四步:applicationContext.xml

<?xml version="1.0"encoding="UTF-8"?>
<beansxmlns="http://www.springframework.org/schema/beans"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xmlns:context="http://www.springframework.org/schema/context"
       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
        http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd
"
>
    <!--00.识别jdbc.properties文件-->
    
<context:property-placeholderlocation="jdbc.properties"></context:property-placeholder>

<!--01.建立数据源   Spring 内置的一个数据源 DriverManager-->
    
<beanid="dataSource"class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <propertyname="driverClassName"value="${jdbc.driverClassName}"></property>
        <propertyname="url"value="${jdbc.url}"></property>
        <propertyname="username"value="${jdbc.user}"></property>
        <propertyname="password"value="${jdbc.password}"></property>
    </bean>
    <!--02.jdbcTemplate 配置-->
    
<beanid="jdbcTemplate"class="org.springframework.jdbc.core.JdbcTemplate">
        <propertyname="dataSource"ref="dataSource"></property>
    </bean>

<!--03.dao配置-->
    
<beanid="bookDao"class="cn.dao.imp.userdaoimp">
        <propertyname="jdbcTemplate"ref="jdbcTemplate"></property>
    </bean>

<!--04.service   bookService-->
    
<beanid="bookService"class="cn.service.impl.BookDAOImpl">
        <propertyname="dao"ref="bookDao"></property>
    </bean>

</beans>
第五步:service层

实现层:

public class BookDAOImplimplements IBookService {

//植入dao
    
privateuserdao dao;

public List<User> findAll() {
        return dao.findAll();
    }

public userdao getDao() {
        return dao;
    }

public void setDao(userdao dao) {
        this.dao= dao;
    }
}

接口层:

//01.查询素有图书
public List<User> findAll();

 

第六步:单测类

@Test
// 01.jdbctemplate
public void test02(){
    ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml");
    IBookService service = (IBookService) ctx.getBean("bookService");
    List<User> list = service.findAll();
    for (User item:list) {
        System.out.println(item.getBookname());
    }
}

事务

七:事务实现(买股票案例)

A:dao层

a:接口层

Account类:

public interface Accountdao {
    //开户方法
    
public boolean add(Account account);
    //修改账户金额 为true
    
public  boolean update(int aid,double blance,boolean isbuy);
}

股票接口:

Account接口实现类:

public interface Stockdao {
    public boolean addstock(stock st);
    public  boolean update(int sid,int count,boolean isUser);
}

b:接口实现层:

public class Accountimp extends JdbcDaoSupport implements Accountdao

{
    public boolean add(Account account) {
        return false;
    }

public boolean update(int aid, double blance, boolean isbuy) {
        boolean flag=false;
        String sql=null;
        if (isbuy){  //购买股票
            
sql="update acount set blance=blance-? where aid=?";
        }else{
            sql="update account set blance=blance+? where aid=?";
        }
        int count = this.getJdbcTemplate().update(sql, blance, aid);
        if (count>0){
            flag=true;
        }
        return flag;
    }
}

股票接口实现类 stock:

public class Stockdaoimp extends JdbcDaoSupport implements Stockdao{

public boolean addstock(stock st) {
        return false;
    }

public boolean update(int sid, int count, boolean isUser) {
        boolean flag=false;
        String sql=null;
        if (isUser){
            sql="update stock set count=count+? where sid=?";
        }else{
            sql="update stock set count=count-? where sid=?";
        }
        int str = this.getJdbcTemplate().update(sql, count, sid);
        if (str>0){
            flag=true;
        }
        return flag;

}

Service层:

接口:

public interface Accountdaoservicedao {
    //开户方法
    
public boolean add(Account account);
    public boolean addstock(stock st);
    public void stock(int aid,double blance,int sid,int count) throws Exception;

}

接口实现:

public class Accountserviceimp implements Accountdaoservicedao {

private Accountdao accountDAO;

private Stockdao stockDAO;
    public void stock(int aid, double blance, int sid, int count) throws Exception {
        //默认是购买股票
        
boolean isBuy=true;
        accountDAO.update(aid,blance,isBuy);

//编译时异常  SPring处理 方式
        //编译时 SPring事务自动提交

//运行时   SPring 自动回滚
        
if(1==1) {
            throw new StockException();
    }
        //02.股票表
        
stockDAO.update(sid,count,isBuy);
    }
    public Accountdao getAccountDAO() {
        return accountDAO;
    }

public void setAccountDAO(Accountdao accountDAO) {
        this.accountDAO = accountDAO;
    }

public Stockdao getStockDAO() {
        return stockDAO;
    }

public void setStockDAO(Stockdao stockDAO) {
        this.stockDAO = stockDAO;
    }

public boolean add(Account account) {
        return false;
    }

public boolean addstock(stock st) {
        return false;
    }

异常类:

public class StockException extends Exception {
    public StockException() {
    }

public StockException(String message) {
        super(message);
    }
}

实体类:

Xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xmlns:context="http://www.springframework.org/schema/context"
       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
        http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd"
>
    <!--00.识别jdbc.properties文件-->
    
<context:property-placeholder location="jdbc.properties"></context:property-placeholder>
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="${jdbc.driverClassName}"></property>
        <property name="jdbcUrl" value="${jdbc.url}"></property>
        <property name="user" value="${jdbc.user}"></property>
        <property name="password" value="${jdbc.password}"></property>
    </bean>
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
        <property name="dataSource" ref="dataSource"></property>
    </bean>
    <!--03.dao配置-->
    
<bean id="Accountdao" class="Spring01tx.cn.dao.imp.Accountimp">
        <property name="jdbcTemplate" ref="jdbcTemplate"></property>
    </bean>
    <bean id="Stockdao" class="Spring01tx.cn.dao.imp.Stockdaoimp">
        <property name="jdbcTemplate" ref="jdbcTemplate"></property>
    </bean>
    <!--04.service   bookService-->
    
<bean id="bookService" class="Spring01tx.cn.service.imp.Accountserviceimp">
    <property name="accountDAO" ref="Accountdao"></property>
        <property name="stockDAO" ref="Stockdao"/>
</bean>

<!--事务管理器-->
    
<bean id="transcationManger" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"></property>
    </bean>
    <!--配置事务 拦截器业务方法-->
    
<bean id="accountServiceProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
        <property name="target" ref="bookService"></property>
        <property name="transactionManager" ref="transcationManger"></property>
        <!--增强-->
        
<property name="transactionAttributes">
            <props>
                <prop key="buy*">ISOLATION_DEFAULT,PROPAGATION_REQUIRED,-StockException</prop>
            </props>
        </property>
    </bean>
</beans>

单测:

public class test {
    @Test
    // 01.jdbctemplate
    
public void test02() {
        ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext01.xml");
        Accountserviceimp service = (Accountserviceimp) ctx.getBean("accountServiceProxy");
        try {
            //数据不匹配时的情况 一个变,一个不变
            
service.stock(1,1000,1,8);
        } catch (Exception e){
            e.printStackTrace();
        }
    }

springJDBC 事物隔离的更多相关文章

  1. SQL事物隔离级别

    标准SQL定义了4个隔离级别 Read uncommitted 未提交读 Read committed 已提交读 Repeatable read 可重复读 Serializable 可序列化 基本语法 ...

  2. spring事物传播机制 事物隔离级别

    Spring事务类型详解: PROPAGATION_REQUIRED--支持当前事务,如果当前没有事务,就新建一个事务.这是最常见的选择. PROPAGATION_SUPPORTS--支持当前事务,如 ...

  3. 07: mysql锁和事物隔离

    MySQL其他篇 目录: 1.1 MySQL中的事物 1.2 mysql中锁 1.1 MySQL中的事物返回顶部 1.InnoDB事务原理 1. 事务(Transaction)是数据库区别于文件系统的 ...

  4. Spring事物隔离级别及事物传播行为@Transactional实现

    阅读本篇文章前,请先阅读如下文章: 四种事物隔离级别详解 先看下@Transactional可以配制那些参数及以其所代表的意义. isolation 枚举org.springframework.tra ...

  5. MySQL数据库的事物隔离级别

    一. 查看数据库的事物隔离级别 mysql> show variables like '%isolation'; +-----------------------+--------------- ...

  6. MVCC原理 4步 什么是MVCC、事务ACID、事物隔离级别、Innodb存储引擎是如何实现MVCC的

    MVCC是来处理并发的问题,提高并发的访问效率,读不阻塞写.事物A 原子性C 一致性I 隔离性D 持久性高并发的场景下的问题脏读不可重复读幻读事物隔离级别RU读未提交 脏读/不可重复读/幻读 .不适用 ...

  7. Oracle中事物处理--事物隔离级别

    n  事物隔离级别 概念:隔离级别定义了事物与事物之间的隔离程度. ANSI/ISO SQL92标准定义了一些数据库操作的隔离级别(这是国际标准化组织定义的一个标准而已,不同的数据库在实现时有所不同) ...

  8. MySQL是如何实现事物隔离?

    前言 众所周知,MySQL的在RR隔离级别下查询数据,是可以保证数据不受其它事物影响,而在RC隔离级别下只要其它事物commit后,数据都会读到commit之后的数据,那么事物隔离的原理是什么?是通过 ...

  9. Hibernate 事物隔离级别 深入探究

    目录 一.数据库事务的定义 二.数据库事务并发可能带来的问题 三.数据库事务隔离级别 四.使用Hibernate设置数据库隔离级别 五.使用悲观锁解决事务并发问题 六.使用乐观锁解决事务并发问题 Hi ...

随机推荐

  1. [APIO 2017] 商旅

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=5367 [算法] 很明显的分数规划问题 预处理从一个点走到另一个点所获最大利润和最短路 ...

  2. 宿主机 && docker 常用命令

    宿主机 && docker 常用命令 1.如果你想快速发现在该主机上使用最多资源的容器(或是最近的所有systemd服务),我推荐systemd-cgtop命令: 2.

  3. Outlook 开发2

    转自:http://www.cnblogs.com/madebychina/archive/2011/09/20/madebychina_2.html C#使用如下代码调用Outlook2003发送邮 ...

  4. 利用PDF.JS插件解决了本地pdf文件在线浏览问题(根据需要隐藏下载功能,只保留打印功能)

    我是在IE11和谷歌上做的测试,都可以显示,把做出的东西记录下来,方便大家还有自己学习! 可以在IIS7服务器上也可以下载Tomcat来做服务器 Tomcat下载地址   http://pan.bai ...

  5. Bean的基于注解的配置方式

    Boss.class import javax.annotation.PostConstruct; import javax.annotation.PreDestroy; import javax.a ...

  6. error:对‘vtable for new_sequence’未定义的引用 对‘typeinfo for num_sequence’未定义的引用

    在设计父类子类继承关系中,经常会出现此类问题. 报错原因:父类中的虚函数只有声明,没有定义. 解决方案 : 1. 定义相关的虚函数的实现. 2. 不实现了,直接搞成纯虚函数留给后代实现. virtua ...

  7. 20个Flutter实例视频教程-第08节: 保持页面状态

    博客地址: https://jspang.com/post/flutterDemo.html#toc-bb9 视频地址: https://www.bilibili.com/video/av397092 ...

  8. FlashkUI v1.33 发布(提供移动设备支持)

    v1.33 Beta更新内容:增加对移动设备的支持,新增自定义双渲染器双层树组件.List增加按数据子项排序功能. <ignore_js_op> 介绍: Flex已经不作为Adobe官方支 ...

  9. HDU - 6016 Count the Sheep 二分图+思维

    Count the Sheep 题意: 问题描述 开学翘课固然快乐,然而也有让呃喵抓狂的事,那当然就是考试了!这可急坏了既要翘课又想要打BC还要准备考试的呃喵. 呃喵为了准备考试没有时间刷题,想打BC ...

  10. DOM学习笔记(二)对象方法与属性

    所有 HTML 元素被定义为对象,而编程接口(对象的访问)则是对象方法和对象属性. 事实上,常用的只用window对象及其子对象document对象,以及事件Event对象. Window 对象 Wi ...