java 之DelayQueue,TaskDelayed,handlerFactory,dataChange消息配置.收发等.java spring事务处理TransactionTemplate
java 之DelayQueue,TaskDelayed,handlerFactory,dataChange消息配置.收发等.java spring事务处理TransactionTemplate等.
================================================================================
事物处理:
public class HelloWorld{
private DataSource dataSource;
//获取数据源
public void setDataSource(DataSource dataSource){
this.dataSource = dataSource;
}
Connection conn = null;
Statement stmt = null;
try{
//获取数据连接
conn = dataSource.getConnection();
//开始事务
conn.setAutoCommit(false);
stmt = conn.createStatement();
//执行想要操作
stmt.executUpdat(...);
//执行成功则提交事务
conn.commit();
}catch(....){
if(conn != null){
//执行不成功,则回滚
conn.roolback();
}catch(...){...}
}finally{...}
}
public interface PlatformTransactionManager{
//目前的事务
TransactionStatus getTransaction(TransactionDefinition definition) throws TransactionException;
//提交事务
void commit(TransactionStatus status) throws TransactionException;
//事务回滚
void rollback(TransactionStatus) throws TransactionException;
}
public interface TransactionDefinition{
//获得事务的传播行为
int getPropagationBehavior();
//获得事务的隔离层次
int getsolationLevel();
//判断事务是否超时
int getTimeour();
//是否为只读事务
boolean isReadOnly();
//返回一个事务的名字
String getName();
}
public interface TransactionStatus{
//判断是否是一个新事务
boolean isNewTransaction();
//设定为只读事务
void setRollbackOnly();
//判断是否是只读事务
boolean isRollbackOnly();
//判断一个事务是否完成
boolean isCompleted();
}
TransactionTemplate extends DefaultTransactionDefinition implements InitializingBean{
private PlatformTransactionManager tranactionManger = null;
//通知依赖注入
publc TransactionTemplate(PlatformTransactionManager transactionManager){
this.transactionManager = transactionManager;
}
public void setTransactionManager(PlatformTransactionManager transaction transactionManager){
this.transactionManger = transactionManager;
}
public PlatformTransactionManager getTransactionManager){
return transactionManager;
}
//执行完毕后调用
public void afterPropertiesSet(){
if(this.transactionManager == null){
throw new IllegalArgumentException("xxxxx");
}
}
//在这里进行事务处理
public Object execute(TransactionCallback action) throws TransactionException{
TransactionStatus status = this.transactionManager.getTransaction(this);
Object result = null;
try{
//执行具体方法
result = action.doInTransaction(status);
}catch(RuntimeException ex){
rollbackOnException(status, ex);
throw ex;
}catch(Error err){
rollbackOnException(status, err);
throw err;
}
this.transactionManager.commit(status);
return result;
}
//如果有异常就rollback
private void rollbackOnException(TransactionStatus status, Throwable ex) throws TransactionException{
try{
this.transactionManager.rollback(status);
}catch(RuntimeException ex2){
throw ex2;
}catch(Error err){
throw err;
}
}
}
publc class HelloDAO{
private DataSource dataSource;
private PlatformTransactionManager transactionManager;
//通过依赖注入来完善管理
public void setDataSource(DataSource dataSource){
this.dataSource = dataSource;
}
public void setTransactionManager(PlatformTransactionManager transactionManager){
this.transactionManager = transactionManager;
}
//该方法进行事务处理
public int create(String msg){
TranactionTemplate transactionTemplate(transactionManager);
Object result = transactionTemplate.execute(new TransactionCallback(){
public Object doInTransaction(TransactionStatus status){
//执行操作
return resultObject;
}
});
}
}
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<!--使用SQLServer数据库-->
<property name="driverClassName">
<value>com.microsoft.jdbc.sqlserver.SQLServerDriver</value>
</property>
<!--设定url-->
<property name="url">
<value>jdbc:microsoft:sqlserver://localhost:1433/stdb</value>
</property>
<!--设定用户名-->
<property name="name">
<value>sa</value>
</property>
<!--密码-->
<property name="msg">
<value>123</value>
</property>
</bean>
<!--设定transactionManager-->
<bean id="transactinManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource">
<ref bean="dataSource">
</property>
</bean>
<!--示例中的一个dao-->
<bean id="helloDAO" class="com.langfei.xxxx.HelloDAO">
<property name="dataSource">
<ref bean="dataSource">
</property>
<property name="transactionManager">
<ref bean="transactionManager"/>
</property>
</bean>
public class HelloDao{
private DataSource dataSource;
privata JdbcTemplate jdbcTemplate;
//依赖注入
public void setDataSource(DataSource dataSource){
this.dataSource = dataSource;
jdbcTemplate = new JdbcTemplate(dataSource);
}
//注意这里看不到事务处理的代码,都在配置文件中
public void create(String sql){
jdbcTemplate.update(sql);
}
}
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManageDataSource">
<!--使用SQLServer数据库-->
<property name="driverClassName">
<value>com.microsof.jdbc.sqlserver.SQLServerDriver</value>
</property>
<!--设定URL-->
.....
<!--设定用户名-->
....
<!--设定密码-->
....
</bean> <!--设定transactionManager-->
....
<bean id="transactionManager">
</>
..... <!--Dao-->
。。。。。
<!--声明事务处理-->
<bean id="helloDAOProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name ="transactionManager">
<ref bean="transactionManager"/>
</property>
<!--指明代理的是HelloDAO类-->
<property name="target">
<ref bean="helloDAO">
</property> <property name="transactionAttributes">
<props>
<!--表示HelloDAO中的create()方法进行事务管理,并指明如果当前没有事务,就新建一个事务-->
<prop key="create">PROPAGATION_REQUIERD</prop>
</props>
</property> <!--
PROPAGATION_REQUIRED: 如果当前没有事务,就新建一个事务
PROPAGATION_SUPPORTS: 如果当前没有事务,就以非事务方式执行
PROPAGATION_MANDATORY: 如果当前没有事务,就抛出异常
PROPAGATION_REQUIRES_NEW:新建事务,如果当前存在事务,把当前事务挂起
PROPAGATION_NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,就把当前事务挂起
PROPAGATION_NEVER: 以非事务方式执行,如果当前存在事务,则抛出异常 -->
</bean>
java 之DelayQueue,TaskDelayed,handlerFactory,dataChange消息配置.收发等.java spring事务处理TransactionTemplate的更多相关文章
- 写给大忙人的ELK最新版6.2.4学习笔记-Logstash和Filebeat解析(java异常堆栈下多行日志配置支持)
接前一篇CentOS 7下最新版(6.2.4)ELK+Filebeat+Log4j日志集成环境搭建完整指南,继续对ELK. logstash官方最新文档https://www.elastic.co/g ...
- ELK学习笔记之Logstash和Filebeat解析对java异常堆栈下多行日志配置支持
0x00 概述 logstash官方最新文档.假设有几十台服务器,每台服务器要监控系统日志syslog.tomcat日志.nginx日志.mysql日志等等,监控OOM.内存低下进程被kill.ngi ...
- Java微信公众平台开发_03_消息管理之被动回复消息
GitHub源码:https://github.com/shirayner/weixin_gz 一.本节要点 1.回调url 上一节,我们启用服务器配置的时候,填写了一个服务器地址(url),如下图, ...
- JAVA基础篇NO1--环境变量的配置及命名规则
标签(空格分隔): java基础 一:计算机概述 计算机:硬件和软件 硬件:控制器 运算器 存储器 输入和输出设备 存储器:外存(硬盘) 内存 软件:系统软件 应用软件 系统软件:wi ...
- Java学习笔记一——安装JDK并配置环境变量
下载安装JDK1.8 在官网上下载JDK,官网地址:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-213 ...
- Java/javaEE/web/jsp/网站编程环境配置及其软件下载和网站路径
Java/javaEE/web/jsp/网站编程环境配置及其软件下载和网站路径 (2015/07/08更新) JDK下载地址(JDK官网下载地址) 下载地址为:http://www.oracle.co ...
- Java Socket发送与接收HTTP消息简单实现
在上次Java Socket现实简单的HTTP服务我 们实现了简单的HTTP服务,它可以用来模拟HTTP服务,用它可以截获HTTP请求的原始码流,让我们很清楚的了解到我们向服务发的HTTP消息的结 构 ...
- java Android SDK安装与环境变量配置以及开发第一个Android程序
JAVA的安装与环境变量的配置 1.先下载JAVA,并且安装. 下载地址:http://www.oracle.com/technetwork/java/javase/downloads/jdk-7u3 ...
- EditPlus配置[C++] [Python] [Java] 编译运行环境
以前一直用Codeblocks写C++,eclipse写Java,再在eclipse里面集成PyDev写Python,首先无法忍受代码自动补全功能(这个功能也许你万分喜欢),也无法忍受如此重量级的ID ...
随机推荐
- grub的安装与配置-------引导redhat grub
1.安装 有两种方法: a.在联网的情况下,用新立德安装: apt-get install grub b.在没网的时候,特别是linux网卡驱动没有安装: 自己从http://packages.ubu ...
- 居于mtk芯片安卓车机系统具体流程
一:车机系统框架 MCU 功能 电源控制 Radio 控制(RDS) 按键检测(Panel/Remote/SW) 常见信号检查(倒车/大灯/刹车) CAN 模块通讯 ARM- ...
- 反射获取成员方法(Method)
1.1.1 反射公开的非静态的成员方法 Method getDeclaredMethod(String name,Class ... parameterTypes)获取某个方法. 说明: 1)在Cla ...
- mongodb的安装和权限管理
mongodb4.0已经发布,但是鉴于线上环境更多的是使用旧版本的mongodb,我们这里使用的mongodb3.4版本. 官网下载地址为:https://fastdl.mongodb.org/lin ...
- P1941 飞扬的小鸟(背包)
P1941 飞扬的小鸟 细节题 上升是完全背包 下降是01背包 (数组访问越界本机怎么能过???(大雾)) #include<iostream> #include<cstdio> ...
- cmd中执行jar文件命令(待参数)
cmd中执行jar文件命令(待参数) 1,jar文件路径:F:\products 2,cmd命令: --两个日期参数(空格隔开) java -jar F:\products\analysis.jar ...
- 20145326 《Java程序设计》第9周学习总结
20145326 <Java程序设计>第9周学习总结 教材学习内容总结 第十六章 一.JDBC入门 1.JDBC简介 JDBC是用于执行SQL的解决方案,开发人员使用JDBC的标准接口,数 ...
- 线程池ThreadPoolExecutor里面4种拒绝策略
ThreadPoolExecutor类实现了ExecutorService接口和Executor接口,可以设置线程池corePoolSize,最大线程池大小,AliveTime,拒绝策略等.常用构造方 ...
- 安装基础版的kinetic
没有gui工具 sudo apt-get install ros-kinetic-ros-base
- pairs 和 ipairs区别
local tab= { [] = "a", [] = "b", [] = "c" } for i,v in pairs(tab) do - ...