成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SQL Server數據庫利用SQL語句使用事務詳解

數據庫 SQL Server
本文我們通過具體的代碼示例來介紹了SQL Server數據庫對事務的使用,希望能夠對您有所幫助。

SQL Server數據庫中對事務的使用是本文我們要介紹的內容,我們首先創建數據庫和表,然后再介紹利用SQL語句來使用事務的操作,接下來就讓我們一起來了解一下這部分內容吧。

--建庫

  1. IF EXISTS (SELECT name FROM sys.databases WHERE name = N'TransTestDb')   
  2. drop database [TransTestDb]   
  3. CREATE DATABASE [TransTestDb];  

--建表

  1. use [TransTestDb]   
  2. go   
  3. IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[TransTestTable]') AND type in (N'U'))   
  4. drop table [TransTestTable]   
  5.  
  6. CREATE TABLE [dbo].[TransTestTable](Id int, [Name] varchar(16));  

--初始值

  1. use [TransTestDb]   
  2. go   
  3. insert into [TransTestTable]   
  4. select 1,'a' union   
  5. select 2,'b' union   
  6. select 3,'c';  

 

--建庫

  1. IF EXISTS (SELECT name FROM sys.databases WHERE name = N'TransTestDb')  
  2. drop database [TransTestDb] CREATE DATABASE [TransTestDb];  

 

--建表

  1. use [TransTestDb] go IF EXISTS (SELECT * FROM sys.objects   
  2. WHERE object_id = OBJECT_ID(N'[dbo].[TransTestTable]') AND type in (N'U'))   
  3. drop table [TransTestTable]   
  4. CREATE TABLE [dbo].[TransTestTable](Id int, [Name] varchar(16));  

 

--初始值

 

  1. use [TransTestDb] go insert into [TransTestTable]   
  2. select 1,'a' union select 2,'b' union select 3,'c'; 

 

-- 首先介紹利用SQL語句來使用事務。Sql Server2005/2008提供了begin tran,commit tran和rollback tran三個語句來顯示的使用事務。begin tran表示事務開始,commit tran表示事務提交,rollback tran表示事務回滾。具體代碼如下:

 

  1. begin try   
  2. begin tran   
  3. insert into dbo.TransTestTable values (66,'66');   
  4. update dbo.TransTestTable set [Name] = '88' where [Id] = 66;   
  5. -- RAISERROR ('Error raised in TRY block.',16,1);   
  6. commit tran   
  7. end try   
  8. begin catch   
  9. rollback tran   
  10. end catch 

 

代碼中的begin try和begin catch是捕獲異常時使用的,只在sql server2005/2008中支持,sql server 2000上不支持這個語句。在begin try 和 end try之間的代碼運行時如果發生異常,則程序會跳轉到begin catch和end catch中執行相關的rollback tran回滾操作。在begin tran和commit tran之間就是一個事務,insert和update必須同時成功,否則就同時失敗。RAISERROR 語句的意思是拋出一個異常,只在sql server2005/2008中支持,sql server 2000上不支持這個語句。

執行上面的代碼,我們會發現,插入和更新同時都成功了。把RAISERROR的注釋去掉后,再執行,我們會發現,插入和更新都回滾了。因為RAISERROR拋出異常后,沒有執行到commit tran,而是直接執行begin catch里面的rollback tran回滾語句了。這里可以看到事務的原子性原則和一致性原則,同時更改同時插入。

以上就是SQL Server數據庫中使用事務的過程,本文就介紹到這里了,希望本次的介紹能夠對您有所幫助。

【編輯推薦】

  1. 關閉SQL Server 2005遠程連接以及其它對外服務
  2. SQL Server數據庫ROW_NUMBER()函數使用詳解
  3. SQL Server將視圖或表的記錄不重復地插入到另一個表
  4. SQL Server 2005附加數據庫時Read-Only錯誤的解決方案
  5. SQL Server中CROSS APPLY和OUTER APPLY的應用詳解

 

責任編輯:趙鵬 來源: 博客園
相關推薦

2010-09-06 09:53:41

SQL Server語句

2011-08-11 09:12:31

SQL Server nolock

2021-03-18 08:20:19

SQLServer數據庫SQL

2010-06-28 10:36:42

SQL Server數

2011-09-01 19:00:08

SQL ServerDBCC語句

2011-08-22 11:39:53

SQL Server數PIVOT

2011-08-24 12:49:56

SQL Server托管代碼

2010-07-15 15:37:13

SQL Server數

2010-09-06 09:36:51

SQL語句

2010-07-15 17:28:50

SQL Server

2011-03-31 09:30:27

SQL Server數管理SQL

2010-09-06 11:05:05

SQL SERVER語句

2011-08-01 22:41:49

SQL Server數Insert

2010-09-07 15:20:58

SQL語句事務

2011-08-15 11:24:46

SQL Server事務

2011-08-15 13:48:47

SQL ServerROW_NUMBER(

2011-08-22 13:28:56

FOR XMLSQL Server

2010-07-13 10:43:26

SQL Server數

2010-09-25 15:37:38

SQL語句

2011-08-25 13:41:50

SQL Server 變更跟蹤
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 青娱乐自拍 | 国产 欧美 日韩 一区 | 国产一区二区三区www | www日本在线 | 伊人网91 | 中文字幕在线第二页 | 国产精品免费一区二区三区 | 亚洲精品99 | 国产精品视频免费播放 | 亚州av在线| 亚洲区在线 | 99reav| 99tv| 国产精品视频在线观看 | 亚洲最大的黄色网址 | 天天人人精品 | 视频二区在线观看 | 一区二区三区精品在线视频 | 国产免费一区二区 | 最新中文字幕在线 | 亚洲视频在线免费观看 | 欧美一区二区三区视频 | 超碰精品在线 | 91高清视频在线观看 | 日韩三级免费观看 | 久久精品成人 | 激情六月丁香 | 国产精品久久久久aaaa樱花 | 日本羞羞影院 | 国产日韩一区二区 | 国产视频在线一区二区 | 亚洲精品美女在线观看 | pacopacomama在线 | 水蜜桃亚洲一二三四在线 | 久久久久九九九女人毛片 | 激情五月婷婷综合 | 成人毛片一区二区三区 | 国产成人一区二区三区电影 | 色综合色综合网色综合 | 91久久看片 | 国产精品日日做人人爱 |