文档章节

事务的使用

我只是一只小小鸟
 我只是一只小小鸟
发布于 2016/06/17 22:09
字数 827
阅读 33
收藏 5
点赞 0
评论 0

为什么要有事务?

  假设我们在进行银行转帐的时候,至少会执行两条SQL语句,一条SQL语句是减少转帐人里帐户的钱,一条是增加收帐人里帐户钱。 例如有一个朋友要转帐1000元:1、那么转帐人的银行里的钱减少1000                

      2、那么收帐人的银行里的钱增加1000

 

  我们往深一点想,在执行这两条SQL语句的时候,会不会发生问题?会,有时候天灾,人祸的。例如。在执行第一条SQL语句的时候,就在这0.001秒之间机器突然出现故障,那么这时候有可能第二条SQL语句没有执行。那这时候转帐人不就很惨,他自己转帐了1000元,自己帐户已经扣了钱,可是对方的帐户没收到钱,那么对方会很生气的认为你没有给他转帐。

  这还是两条SQL语句出现问题的情况,试想如果银行在处理事务时有100条SQL语句要执行,每条都很重要,那么出现问题的概率不是更大了吗?为了针对这种情况出现了事务。

 

那么什么是事务?

  事物是指访问并可能更新数据库中各种新据项的一个程序执行单行(UNIT),也就是由多个SQL语句组成,必需作为一个整体执行。 事物说白了一点,就是同生共死,意思要么全部的SQL语句都执行成功,要么全部的SQL语句都执行失败。所以为了防止上面那种情况,要么两条SQL语句都执行成功,要么两条SQL语句都执行失败。

 

通过例子来了解一下事务,在举个例子前先看一下,先看几个事务常用到的词

  •  开始事务:BEGIN TRANSACTION
  •  事务提交:CIMMIT TRANSACTION
  •  事务回滚: ROLL BACK TRANSACTION
  •  查看语句有没有错误: @@ERROR

当没有发生错误的时候便可以将事务进行提交(CIMMIT TRANSACTION),而查看有没有SQL语句的执行错误,可以用 @@ERROR来进行查看。当发生错误的时候便使用(ROLL BACK TRANSACTION)将SQL语句回滚到最最之前,没有执行SQL语句那时候。

 

先来通过表后插入两条SQL语句再更新,看一下失败的情况

代码如下:

View Code

--消息 547,级别 16,状态 0,第 1 行
--UPDATE 语句与 CHECK 约束"CK__bank__balance__0519C6AF"冲突。该冲突发生于数据库"test",表"dbo.bank", column 'balance'。
--语句已终止。
--(1 行受影响)

select * from bank

bid balance

001  1000.00

002  1100.00

 查看结果发现 002的值增加了1000,但是001的值并没有变为0。

如何用SQL语句创建事务,避免上面那种情况

DECLARE @sumError int
set @sumError=0
BEGIN TRANSACTION
    update bank set balance=balance-1000 where bid='001';
    set @sumError = @sumError +@@Error
    update bank set balance=balance+1000 where bid='002';
    set @sumError = @sumError +@@Error
    
    IF(@sumError = 0)
        BEGIN
            COMMIT TRANSACTION
        END
    ELSE
        BEGIN
            ROLLBACK TRANSACTION
        END

--通过上面的事务代码,两条代码要么同时执行成功,要么同时执行失败

转自博客园:http://www.cnblogs.com/cxeye/archive/2012/08/17/2643482.html

本文转载自:http://www.cnblogs.com/cxeye/archive/2012/08/17/2643482.html

共有 人打赏支持
我只是一只小小鸟
粉丝 14
博文 98
码字总数 52982
作品 1
荆州
程序员
Spring 事务传播行为

如果对事务不了解的可以先看下,我的上一篇文章: 数据库事务详解 概述 一般SSH的项目都是使用三层架构即Controller、Services、DAO。 Spring 的事务一般都在Services定义,而Controller、D...

jijs ⋅ 01/07 ⋅ 0

☆Spring 事务机制详解

Spring事务机制主要包括,此处侧重讲解声明式事务,编程式事务在实际开发中得不到广泛使用,仅供学习参考。 Spring声明式事务让我们从复杂的事务处理中得到解脱。使得我们。再也无需要我们在...

书海陶然 ⋅ 2017/12/21 ⋅ 0

Spring事务传播特性

传播特性 该特性是保证事务是否开启,业务逻辑是否使用同一个事务的保证。当事务在传播过程中会受其影响。其传播特性包括: 1、Propagation.REQUIRED 方法被调用时自动开启事务,在事务范围内...

JieYao ⋅ 03/02 ⋅ 0

JAVA之JDBC简单事务处理

1、什么是Java事务 通常观念认为,事务与数据库有关。事务是访问数据库的一个操作序列,数据库应用系统通过事务集来完成对数据库的存取。事务的正确执行使得数据库从一种状态转换成另一种状态...

火龙战士 ⋅ 2015/08/17 ⋅ 5

weblogic DataSource 配置注意事项 .

weblogic 创建datasource时,配置注意事项,记录一下weblogic 的doc。 事务选项 使用管理控制台配置 JDBC 数据源时,WebLogic Server 会根据 JDBC 驱动程序的类型自动选择特定的事务选项: ...

pczhangtl ⋅ 2013/11/22 ⋅ 0

Spring事务隔离级别和传播性

Spring事务配置属性: 属性 类型 默认值 说明 propagation Propagation REQUIRED 事务传播属性 isolation isolation DEFAULT 事务隔离级别 readOnly boolean false 只读事务 timeout int -1...

克温s ⋅ 2016/01/11 ⋅ 0

事务的编程模型

在上一篇文章里面写了关于事务的一些特性,这里在谈谈事务的编程模型。什么叫做事务的编程模型,这个问题比较难以回答,其实简单的一句话,就是我们如何去使用和控制事务。在java平台里面,有...

真爱2015 ⋅ 2016/05/19 ⋅ 0

spring 事物管理特性

采用编程式事务 1、 getCurrentSession()与openSession()的区别? 采用getCurrentSession()创建的session会绑定到当前线程中,而采用openSession()创建的session则不会 采用getCurrentSessi...

lzw_me ⋅ 2014/07/25 ⋅ 0

【分布式事务系列三】Spring的事务体系

分布式事务 【分布式事务系列一】提出疑问和研究过程 【分布式事务系列二】Spring事务管理器PlatformTransactionManager 【分布式事务系列三】Spring的事务体系 本地事务模型:开发人员不用知...

陶邦仁 ⋅ 2015/12/09 ⋅ 0

编程式事务的简单使用

释义:编程式事务和声明式事务的区别 编程式事务需要在代码中写明事务的提交commit、回滚rollback,如在执行某方法时需要事务处理,你需要在方法开始时开启事务,处理完后,在方法结束时候,...

一只石头 ⋅ 2016/02/18 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

博客迁移到 https://www.jianshu.com/u/aa501451a235

博客迁移到 https://www.jianshu.com/u/aa501451a235 本博客不再更新

为为02 ⋅ 35分钟前 ⋅ 0

win10怎么彻底关闭自动更新

win10自带的更新每天都很多,每一次下载都要占用大量网络,而且安装要等得时间也蛮久的。 工具/原料 Win10 方法/步骤 单击左下角开始菜单点击设置图标进入设置界面 在设置窗口中输入“服务”...

阿K1225 ⋅ 今天 ⋅ 0

Elasticsearch 6.3.0 SQL功能使用案例分享

The best elasticsearch highlevel java rest api-----bboss Elasticsearch 6.3.0 官方新推出的SQL检索插件非常不错,本文一个实际案例来介绍其使用方法。 1.代码中的sql检索 @Testpu...

bboss ⋅ 今天 ⋅ 0

informix数据库在linux中的安装以及用java/c/c++访问

一、安装前准备 安装JDK(略) 到IBM官网上下载informix软件:iif.12.10.FC9DE.linux-x86_64.tar放在某个大家都可以访问的目录比如:/mypkg,并解压到该目录下。 我也放到了百度云和天翼云上...

wangxuwei ⋅ 今天 ⋅ 0

PHP语言系统ZBLOG或许无法重现月光博客的闪耀历史[图]

最近在写博客,希望通过自己努力打造一个优秀的教育类主题博客,名动江湖,但是问题来了,现在写博客还有前途吗?面对强大的自媒体站点围剿,还有信心和可能型吗? 至于程序部分,我选择了P...

原创小博客 ⋅ 今天 ⋅ 0

IntelliJ IDEA 2018.1新特性

工欲善其事必先利其器,如果有一款IDE可以让你更高效地专注于开发以及源码阅读,为什么不试一试? 本文转载自:netty技术内幕 3月27日,jetbrains正式发布期待已久的IntelliJ IDEA 2018.1,再...

Romane ⋅ 今天 ⋅ 0

浅谈设计模式之工厂模式

工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。 在工厂模式中,我们在创建对象时不会对客户端暴露创建逻...

佛系程序猿灬 ⋅ 今天 ⋅ 0

Dockerfile基础命令总结

FROM 指定使用的基础base image FROM scratch # 制作base image ,不使用任何基础imageFROM centos # 使用base imageFROM ubuntu:14.04 尽量使用官方的base image,为了安全 LABEL 描述作...

ExtreU ⋅ 昨天 ⋅ 0

存储,对比私有云和公有云的不同

导读 说起公共存储,很难不与后网络公司时代的选择性外包联系起来,但尽管如此,它还是具备着简单和固有的可用性。公共存储的名字听起来也缺乏专有性,很像是把东西直接堆放在那里而不会得到...

问题终结者 ⋅ 昨天 ⋅ 0

C++难点解析之const修饰符

C++难点解析之const修饰符 c++ 相比于其他编程语言,可能是最为难掌握,概念最为复杂的。结合自己平时的C++使用经验,这里将会列举出一些常见的难点并给出相应的解释。 const修饰符 const在c...

jackie8tao ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部