java 使用动态代理 和ThreadLocal实现事务管理实例

动态代理:JDK动态代理只能对实现了接口的类进入代理,采用JDK动态代理必须实现InvocationHandler接口,采用Proxy 类创建相应的代理类.

invoke方法签名:invoke(Object Proxy,Method method,Object[] args)

 public static Object newProxyInstance(ClassLoader loader,Class<?>[] interfaces, InvocationHandler h)
 throws IllegalArgumentException

ClassLoader loader
----指定被代理对象的类加载器
Class[] Interfaces
----指定被代理对象所实现的接口
InvocationHandler h ----指定需要调用的InvocationHandler对象

注意本文是用的mysql5.0之后版本,并且别忘了数据库驱动

创建表:

/*DDL 信息*/------------

CREATE TABLE `t_user` (
  `USER_ID` varchar(10) NOT NULL,
  `USER_NAME` varchar(30) NOT NULL,
  `PASSWORD` varchar(20) NOT NULL,
  `CONTACT_TEL` varchar(30) DEFAULT NULL,
  `EMAIL` varchar(30) DEFAULT NULL,
  `CREATE_DATE` date DEFAULT NULL,
  PRIMARY KEY (`USER_ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

插入的字段

INSERT INTO t_user(user_id, user_name, PASSWORD) VALUES('110', '系统管理员', 'root');

创建事务管理类(单例模式

ConnectionManager

数据库连接管理类,实现对数据库连接和事务的管理.

</

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ThreadLocalJava中的一个线程本地变量工具类,用于在多线程环境下,为每个线程提供独立的变量副本。它的实现原理是通过在每个线程中维护一个ThreadLocalMap对象,该对象以ThreadLocal实例作为key,以对应的值作为value,存储线程的局部变量。 ThreadLocal的应用场景有: 1. 线程安全的对象:如果一个对象在多线程环境中被共享访问,并且它的状态是可变的,那么使用ThreadLocal可以为每个线程提供一个独立的对象副本,避免线程间的竞争和同步问题。 2. 数据库连接管理:在使用数据库连接池时,每个线程需要从连接池中获取数据库连接进行操作,ThreadLocal可以用来存储当前线程所使用的数据库连接,保证每个线程都有自己独立的连接。 3. 事务管理:在多线程环境下,如果某个业务操作需要开启事务,并且事务的隔离级别是线程级别的,则可以使用ThreadLocal来存储当前线程的事务状态,确保每个线程操作的是自己的事务。 4. Web应用中的用户信息存储:在Web应用中,每个请求都会创建一个线程进行处理,可以使用ThreadLocal将用户信息保存在当前线程中,方便在不同的业务逻辑中获取用户信息。 5. 并发工具类中的上下文传递:在一些并发框架和工具类中,可能会需要将一些上下文信息传递给线程池中的线程,使用ThreadLocal可以将上下文信息绑定到当前线程,方便在线程池中进行访问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值