JDBC事务--软件开发三层架构--ThreadLocal
一.JDBC事务
1.概述:
事务是指逻辑上的一组操作!这一组操作,通常认为是一个整体,不可拆分!
特点:同生共死;事务内的这一组操作要么全部成功,要么全部失败!
作用:保证逻辑操作的完整性,安全性!
2.使用(3种方式)
1)面向数据库,使用SQL语句控制
开启;(告诉数据库,我们要开始做事情了,)
START TRANSACTION;
提交;(确认上面所有的操作要生效);
COMMIT;
回滚;(撤销上面所做的所有操作);
ROLLBACK;
2)面向JDBC-Connection 接口(java.sql)
常用方法:
void setAutoCommit(boolean autoCommit) throws SQLException{}:参数默认为true,若要开启,需设置为false;
void commit()throws SQLException{}:提交事务;
void rollback()throws SQLException{}:回滚事务;
3)面向工具DBUtils--QueryRunner 类(org.apache.commons.dbutils);使用Connection对象控制
构造方法:(必须使用空参构造)
public QueryRunner()
常用方法:
public <T> T query(Connection conn,String sql,ResultSetHandler<T> rsh,Object... params)
throws SQLException{}:参数中必须传递开启事务后的Connection对象;执行sql后自己提交或回滚事务;The object returned by the handler.
public int update(Connection conn,String sql,Object... params)throws
SQLException{}:参数中必须传递开启事务后的Connection对象;执行sql后自己提交或回滚事务;Returns:The number of rows updated.
3.注意事项:
1):事务的开启只有一个入口;
2):提交或回滚都是结束事务;
3):如果没有手动开启事务,默认每一条sql语句就是一个独立的事务,当sql执行结束的时候,自动提交了;
4):如果程序执行过程中出现异常情况,默认是回滚;
二.软件开发三层架构
1.概述
所谓的3层架构是一个固定模式,使用这个模式可以快速开发软件;
好处:
1):高内聚;(相似的代码或相似的功能可以集中在一起)
2):低耦合;(代码可以同时开发,只是结果联系在一起)
3):可维护;
4):可重用;
5):可扩展;
2.具体结构:
1):表现层web;(主要用于数据的收集与展示)
2):业务层service;(业务逻辑控制,通常事务会在这里开启并结束)
3):持久层DAO(Data Access Object);(数据层)(对数据进行CRUD,操作数据库的代码写在这里);
4).类:domain;存放javabean
5).工具包:utils;存放工具
三.ThreadLocal<T> 类(java.lang)
概述:
ThreadLocal是一个容器,该容器中定义了一个特殊的变量,该变量保存的是将来线程传递过来的值;每个线程存值的时候,会存在特殊的变量的副本中;将来这些线程从变量中获取的值互不影响,不会出现线程安全的问题;
适用场景:
当一个线程中调用多个方法,不想进行参数传递的时候,可以使用ThreadLocal作为载体,让该线程中的所有方法获取一个值;
定义:public class ThreadLocal<T> extends Object
构造方法:(空参构造)
public ThreadLocal()
常用方法:
public void set(T value){}:the value to be stored in the current thread's copy of this thread-local
public T get(){}:Returns:the current thread's value of this thread-local