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

dede网站地图制作房屋租赁网站建设管理

dede网站地图制作,房屋租赁网站建设管理,网站使用功能介绍是用什么软件做的,网站建设与管理好学吗大多数嵌套事务是使用EJB实现的#xff0c;现在我们尝试在POJO上实现嵌套事务。 在这里#xff0c;我们使用了ThreadLocal的功能。 了解嵌套事务 事务可以嵌套在另一个内部。 因此#xff0c;内部事务或外部事务可以回滚或提交#xff0c;而不会影响其他事务。 创建新事务… 大多数嵌套事务是使用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.html
http://www.yutouwan.com/news/483669/

相关文章:

  • 广告图片怎么制作网站做优化有几种方式
  • 电子商务网站的全面建设建设银行网站用户名忘了怎么办
  • 浏览不良网站会被网警抓吗有关网站建设账务处理
  • 免费的软件网站包头网站建设哪家好
  • 制作简历的免费网站西凤九网站建设的目标
  • 金华建站模板建站平台入口
  • 北京网站建设付款方式网站制作的评价标准
  • 个人摄影网站源码静态网页制作教程视频
  • 摄影网站建设的论文互联网项目招商加盟
  • 网站建设有哪些文件wordpress网站代码
  • 余姚网站建设企业增城企业网站建设
  • 城乡与建设部网站网页设计与网站建设考试名词解释
  • 制作旅游网站设计概述找外包网站 和自己做
  • 昆明网站建站平台用jsp做的网站
  • 做图文的网站网页升级无法自动更新
  • 广州哪家公司做网站西安seo交流
  • 网站 正在建设中西安品牌网站建设
  • 手机网站快速画册设计排版的技巧和规则
  • 无锡哪个网站好wordpress对接火车头
  • seo百度网站排名研究中心关键词首页优化网站建设 镇江
  • 东莞建站响应式网站多少钱网店美工主要负责哪些工作
  • 有什么网站可以接设计单做公司网站设计解决方案
  • 如何建立属于个人网站网站类型定位
  • 网站开发 h5 h4外包公司排行
  • 怎样创造一个网站android编程
  • 最新免费网站源码资源网站wordpress 新闻类主题
  • 建设厅网站福州男同性做基网站
  • 上海建站宝盒做网站前需要做哪些事情
  • 北京网站优化wordpress设置会员时效
  • 企业做网站哪家公司好软文范例100例