一个简单的事务

  从这篇开始要总结事务了,我们就从一个简单的事务示例开始吧。下面这个示例首先定义了一个事务,然后把关于一个新订单的数据记录到数据库中。示例代码如下:

USE TSQLFundamentals2008;
GO

-- 事务
-- 一个简单的事务
BEGIN TRAN;

-- 声明一个变量,保存新的OrderID
DECLARE @neworderid AS INT=0;

-- 将一个新订单插入到Sales.Orders表中
INSERT INTO Sales.Orders
        ( custid ,
          empid ,
          orderdate ,
          requireddate ,
          shippeddate ,
          shipperid ,
          freight ,
          shipname ,
          shipaddress ,
          shipcity ,
          shipregion ,
          shippostalcode ,
          shipcountry
        )
VALUES  ( 85 , -- custid - int
          5 , -- empid - int
          ‘20090212‘ , -- orderdate - datetime
          ‘20090301‘ , -- requireddate - datetime
          ‘20090216‘ , -- shippeddate - datetime
          3 , -- shipperid - int
          32.38 , -- freight - money
          N‘ship to 85-b‘ , -- shipname - nvarchar(40)
          N‘6789 rue de l‘ , -- shipaddress - nvarchar(60)
          N‘Abbaye‘ , -- shipcity - nvarchar(15)
          N‘Reims‘ , -- shipregion - nvarchar(15)
          N‘10345‘ , -- shippostalcode - nvarchar(10)
          N‘France‘  -- shipcountry - nvarchar(15)
        );

-- 将新的订单ID保存到变量中
SET @neworderid= SCOPE_IDENTITY(); --或者@@IDENTITY

-- 返回新的订单ID
SELECT @neworderid AS neworderid;

-- 将新订单的订单明细插入到Sales.OrderDetails表中
INSERT INTO Sales.OrderDetails( orderid ,productid ,unitprice ,qty ,discount)
VALUES ( @neworderid,11 ,14.00 ,12 ,0.000),
        (@neworderid,42,9.80,10,0.000),
        (@neworderid,72,34.80,5,0.000);

-- 提交事务
COMMIT TRAN;

插入数据后的效果如下图:

我们可以看到,成功插入了一个订单和其三笔订单明细。

测试完成后,我们需要运行以下代码清理数据。

-- 清理数据
DELETE FROM Sales.OrderDetails WHERE orderid>11077;
DELETE FROM Sales.Orders WHERE orderid>11077;
DBCC CHECKIDENT(‘Sales.Orders‘,RESEED,11077); -- 重置标识值
时间: 2024-11-02 10:43:08

一个简单的事务的相关文章

spring实现一个简单的事务管理

前两天给公司的数据库操作加了事务管理,今天博客就更一下这个吧. 先说明:本文只是简单得实现一下事务,事务的具体内容,比如事务的等级,事务的具体实现原理等等... 菜鸟水平有限,暂时还更不了这个,以后的博客可能会涉及. 如果您看完本博客之后能简单的实现一个事务,本文目的就达到了. 首先简单通俗的解释一下啥叫事务: 在一个方法里的所有操作数据库的语句,要么全部执行(方法没有报错),要么全部不执行(方法抛错,已经执行的语句回滚). xml形式实现事务,也是我在公司代码中实现的事务.他的好处是不用对现有

一个简单的跨库事务问题

什么是数据结构? 数据结构是相互之间存在一种或多种特定关系的数据元素的集合. 还有一些概念(数据.数据元素.数据项.数据对象.数据类型...) 传统上,我们把数据结构分为逻辑结构和物理结构. 逻辑结构:是指数据对象中数据元素之间的相互关系,也是我们今后最需要关注和讨论的问题. 物理结构:是指数据的逻辑结构在计算机中的存储形式. 逻辑结构分为以下四种: 1.集合:集合结构中的数据元素除了同属于一个集合外,之间没有任何关系. 2.线性结构:元素之间一对一. 3.树形结构:一对多. 4.图形结构:多对

WCF服务二:创建一个简单的WCF服务程序

在本例中,我们将实现一个简单的计算服务,提供基本的加.减.乘.除运算,通过客户端和服务端运行在同一台机器上的不同进程实现. 一.新建WCF服务 1.新建一个空白解决方案,解决方案名称为"WCFSolution". 2.解决方案右键->添加->类库项目,类库名称为CalculateWcfService. 3.创建服务契约 WCF采用基于契约的交互方式实现了服务的自制.服务契约:是相关操作的集合.契约就是双方或多方就某个关注点达成的一种共识,是一方向另一方的一种承诺.签署了某个

为您的Web项目构建一个简单的JSON控制器

摘要:无论您的项目使用的是哪种数据库后端,JavaScript Object Notation (JSON) 控制器都能简化您的开发工作.本文将带领您建立一个能够增强您的下一个开发项目的非常基础的 JSON 控制器. 您的下一个 PHP/MySQL 项目可能与您最近完成的十几个项目类似:建立一个 MySQL 数据库,创建包含 HTML 的 PHP 视图,根据需要添加 JavaScript 代码和 CSS 文件,连接到数据库,从数据库提取内容来填充视图,等等.如果您熟悉 web 开发,您一定知道分

实现iOS图片等资源文件的热更新化(五): 一个简单完整的资源热更新页面

简介 一个简单的关于页面,有一个图片,版本号,App名称等,着重演示各个系列的文章完整集成示例. 动机与意义 这是系列文章的最后一篇.今天抽空写下,收下尾.文章本身会在第四篇的基础上,简单扩充下代码,实现在线下载与重置更改的功能. 如果能较为仔细地阅读前四篇文章,第五篇给出的示例,应当是可以理解为无足轻重的.但是,大多数时候,我们更多的可能只是需要一个简易的解决方案,就是那种拿来就可以用的东西,那种我们需要先能看到一个简要的示例来看下效果再解决是否再继续阅读的方案.如此,对于很久以后,由于各种原

一个简单的ORM制作(SQL帮助类)

一个简单的ORM制作大概需要以下几个类: SQL执行类 CURD操作类 其他酱油类 先从SQL执行类说起,可能会涉及数据库的迁移等问题,所以需要定义一个接口以方便迁移到其他数据库, 事务没提供命名,若需要命名可修改为可变参数,IHelper代码如下: internal interface IHelper:IDisposable { int ExecuteQuery(string txt, IEnumerable<IDataParameter> ps, bool issp);//用于执行INSE

关于apriori算法的一个简单的例子

apriori算法是关联规则挖掘中很基础也很经典的一个算法,我认为很多教程出现大堆的公式不是很适合一个初学者理解.因此,本文列举一个简单的例子来演示下apriori算法的整个步骤. 下面这个表格是代表一个事务数据库D,其中最小支持度为50%,最小置信度为70%,求事务数据库中的频繁关联规则. Tid 项目集 1  面包,牛奶,啤酒,尿布 2  面包,牛奶,啤酒 3  啤酒,尿布 4  面包,牛奶,花生 apriori算法的步骤如下所示: (1)生成候选频繁1-项目集C1={{面包},{牛奶},{

一个简单的iBatis入门例子

一个简单的iBatis入门例子,用ORACLE和Java测试 目录结构: 1.导入iBatis和oracle驱动. 2.创建类Person.java package com.ibeats;import java.util.Date; public class Person { private int id; private String firstName; private String lastName; private double weightInKilograms; private do

jmeter压力测试的简单实例+badboy脚本录制(一个简单的网页用户登录测试的结果)

JMeter的安装:在网上下载,在下载后的zip解压后,在bin目录下找到JMeter.bat文件,双击就可以运行JMeter. http://jmeter.apache.org/ 在使用jmeter前要先下载jdk包,配置java环境.(参见Java环境配置教程) 配置完成后在运行窗口检查一下java -version确定java环境配置完成. 一.利用badboy进行自动脚本录制 下载BadboyInstaller-2.2.5.exe 并安装 下载地址:http://download.csd