当前位置: 首页 > news >正文

上海网站制作找缘魁百度搜索官网

上海网站制作找缘魁,百度搜索官网,网站建设的方案预算,安徽和住房建设厅网站java pojo使用大多数嵌套事务是使用EJB实现的#xff0c;现在我们尝试在POJO上实现嵌套事务。 在这里#xff0c;我们使用了ThreadLocal的功能。 了解嵌套事务 事务可以嵌套在另一个内部。 因此#xff0c;内部事务或外部事务可以回滚或提交#xff0c;而不会影响其他事务… java pojo使用 大多数嵌套事务是使用EJB实现的现在我们尝试在POJO上实现嵌套事务。 在这里我们使用了ThreadLocal的功能。 了解嵌套事务 事务可以嵌套在另一个内部。 因此内部事务或外部事务可以回滚或提交而不会影响其他事务。 创建新事务后它将进入外部事务。 一旦内部事务以提交或回滚的方式完成外部事务就可以执行提交或回滚而与内部事务无关。 首先关闭最内部的事务然后继续进行外部事务。 使用简单POJO实施 创建界面如下 importjava.sql.Connection;publicinterfaceTransactionManager {Connection getConnection();voidbeginTransaction();void commit();void rollback(); } 创建事务管理器类如下所示 importjava.sql.Connection; importjava.sql.DriverManager; importjava.sql.SQLException; importjava.util.Stack;publicclassTransactionManagerStackImplimplementsTransactionManager {private StackConnectionconnections new StackConnection();Overridepublic Connection getConnection() {if (connections.isEmpty()) {this.addConn();}returnconnections.peek();}OverridepublicvoidbeginTransaction() {this.addConn();}Overridepublicvoid commit() {try {if (connections.peek() ! null !connections.peek().isClosed()) {System.out.println(connections.peek().toString() --Commit---);connections.peek().commit();connections.pop().close();}} catch (SQLException e) {e.printStackTrace();}}Overridepublicvoid rollback() {try {if (connections.peek() ! null !connections.peek().isClosed()) {System.out.println(connections.peek().toString() --Rollback---);connections.peek().rollback();connections.pop().close();}} catch (SQLException e) {e.printStackTrace();}}privatevoidaddConn() {try {Connection con this.getMysqlConnection();con.setAutoCommit(false);connections.push(con);System.out.println(con.toString() --Conection---);} catch (SQLException e) {e.printStackTrace();}}private Connection getMysqlConnection() {returngetConnection(com.mysql.jdbc.Driver, jdbc:mysql://localhost:3306/testdb, test, test12345);}private Connection getConnection(String driver, String connection,String user, String password) {try {Class.forName(driver);returnDriverManager.getConnection(connection, user, password);} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();}returnnull;} } 在这里我们创建了一个堆栈 private StackConnection connections new StackConnection(); 由于事务创建为LIFO堆栈因此我们使用了Java API中的Stack来维护每个事务的连接 public void beginTransaction() 开始事务以开始新事务并将连接添加到堆栈。 AutoCommit已设置为false public Connection getConnection() 获取当前事务的连接。 如果不存在它将创建并添加到堆栈中 public void commit() 提交当前事务并关闭连接该连接也已从堆栈中删除 public void rollback() 回滚当前事务并关闭连接该连接也已从堆栈中删除。 上面的TransactionManagerStackImpl类将为单线程创建嵌套事务。 多线程嵌套事务 对于多线程应用程序每个线程都有独立的事务和嵌套事务。 我们提出使用ThreadLocal来管理连接堆栈。 importjava.sql.Connection;publicclassTransactionManagerThreadLocalimplementsTransactionManager {privatestaticfinalThreadLocalTransactionManagertranManager newThreadLocalTransactionManager() {protectedTransactionManagerinitialValue() {System.out.println(this.toString() --Thread Local Initialize--);returnnewTransactionManagerStackImpl();}};OverridepublicvoidbeginTransaction() {tranManager.get().beginTransaction();}Overridepublicvoid commit() {tranManager.get().commit();}Overridepublicvoid rollback() {tranManager.get().rollback();}Overridepublic Connection getConnection() {returntranManager.get().getConnection();} } 在这里我们初始化TransactionManagerStackImpl以在线程内部创建嵌套事务。 测试中 为了进行上述测试请提交内部事务并回滚外部事务。 importjava.sql.Connection;publicclassNestedMainimplements Runnable {privateintv 0;private String name;NestedMain(int v, String name) {this.v v;this.name name;}publicstaticvoid main(String[] args) throws Exception{for (inti 0; i 3; i) {NestedMain main newNestedMain(i * 10, Ravi i);new Thread(main).start();}}Overridepublicvoid run() {try {TransactionManagerThreadLocal local newTransactionManagerThreadLocal();// Transaction 1 ( outer )local.beginTransaction();Connection con local.getConnection();String sql INSERT INTO test_tran (emp_id, name) VALUES (1v, namev);this.insert(con, sql);// Transaction 2 ( Inner )local.beginTransaction();con local.getConnection();sql INSERT INTO test_tran (emp_id, name) VALUES (2v, namev);this.insert(con, sql);local.commit(); // Committing 2local.rollback(); // Rollback 1 Outer} catch (Exception e) {e.printStackTrace();}结果 com.ttit.TransactionManagerThreadLocal$11270b73--Thread Local Initialize-- com.ttit.TransactionManagerThreadLocal$11270b73--Thread Local Initialize-- com.ttit.TransactionManagerThreadLocal$11270b73--Thread Local Initialize-- com.mysql.jdbc.JDBC4Connection10dd1f7--Conection--- com.mysql.jdbc.JDBC4Connection1813fac--Conection--- com.mysql.jdbc.JDBC4Connection136228--Conection--- com.mysql.jdbc.JDBC4Connection1855af5--Conection--- com.mysql.jdbc.JDBC4Connectione39a3e--Conection--- com.mysql.jdbc.JDBC4Connection1855af5--Commit--- com.mysql.jdbc.JDBC4Connectione39a3e--Commit--- com.mysql.jdbc.JDBC4Connection9fbe93--Conection--- com.mysql.jdbc.JDBC4Connection9fbe93--Commit--- com.mysql.jdbc.JDBC4Connection10dd1f7--Rollback--- com.mysql.jdbc.JDBC4Connection1813fac--Rollback--- com.mysql.jdbc.JDBC4Connection136228--Rollback--- 名称 emp_id 拉维220 220 拉维00 20 拉维110 210 回滚内部事务并提交外部事务时 com.ttit.TransactionManagerThreadLocal$11270b73--Thread Local Initialize-- com.ttit.TransactionManagerThreadLocal$11270b73--Thread Local Initialize-- com.ttit.TransactionManagerThreadLocal$11270b73--Thread Local Initialize-- com.mysql.jdbc.JDBC4Connection9f2a0b--Conection--- com.mysql.jdbc.JDBC4Connection136228--Conection--- com.mysql.jdbc.JDBC4Connection1c672d0--Conection--- com.mysql.jdbc.JDBC4Connection9fbe93--Conection--- com.mysql.jdbc.JDBC4Connection1858610--Conection--- com.mysql.jdbc.JDBC4Connection9fbe93--Rollback--- com.mysql.jdbc.JDBC4Connection1858610--Rollback--- com.mysql.jdbc.JDBC4Connection1a5ab41--Conection--- com.mysql.jdbc.JDBC4Connection1a5ab41--Rollback--- com.mysql.jdbc.JDBC4Connection9f2a0b--Commit--- com.mysql.jdbc.JDBC4Connection136228--Commit--- com.mysql.jdbc.JDBC4Connection1c672d0--Commit--- 名称 emp_id 拉维00 10 拉维220 120 拉维110 110 资源 了解ThreadLocal背后的概念 翻译自: https://www.javacodegeeks.com/2013/12/java-nested-transaction-using-threadlocal-in-pojo.htmljava pojo使用
http://www.yutouwan.com/news/404819/

相关文章:

  • 做一个公司的网站应做哪些准备工作内容做软件的网站
  • 解决国外网站很慢免费模板下载网
  • 斐讯路由器做网站映射做网站需要注册什么公司
  • 深圳专业网站建设企永久免费的连外网的软件
  • 网站建站报告网页设计的价格
  • 深圳企业网站文昌湖城乡建设局网站
  • 网站 搜索怎么实现怎么生成二维码
  • 百度云 做视频网站怎么用wix做网站
  • 云南响应式网站建设wordpress到服务器配置
  • 网站 购买德州做网站建设的公司哪家好
  • 深圳做网站开发公司高端企业网站 程序
  • 重庆网站建设qq群网上开店需要营业执照吗
  • 甘肃省集约化网站建设做移门图的 网站有哪些
  • 英语故事网站建设最强大的搜索引擎
  • 网站建设标准依据成都网站建设询q479185700霸屏
  • 百度云域名没有备案怎么做网站百度给公司做网站效果咋样
  • 上海闵行网站建设公司在线技能培训平台
  • 网站功能提升权限什么页游好玩人多
  • 做网站的去哪找私活饭店餐厅网站建设
  • 网站打不开第二天不收录啦做网站推广的方法
  • 长沙cms建站模板wordpress 安装脚本
  • 阜阳企业网站推广wordpress 页面开发
  • 用心做的网站做外贸用哪个网站好
  • 机关内网站建设方案书男人直接做的视频网站
  • 什么网站没人做建设通是正规网站吗
  • 开发网站需求设计个人网站每年要多少钱
  • 汽车网站源码信丰网站建设
  • 开封市建设中专继续教育网站玉林网站优化
  • 怎么查看网站打开速度正在建设的网站可以随时进入吗
  • 点子网站制作旅游景点网站设计