首頁 資料庫 mysql教程 [MSSQL]SQLServer事务语法_MySQL

[MSSQL]SQLServer事务语法_MySQL

May 30, 2016 pm 05:09 PM
事務 文法

事务全部是关于原子性的。原子性的概念是指可以把一些事情当做一个单元来看待。从数据库的角度看,它是指应全部执行或全部都不执行的一条或多条语句的最小组合。
为了理解事务的概念,需要能够定义非常明确的边界。事务要有非常明确的开始和结束点。SQL Server中的每一条SELECT、INSERT、UPDATE和DELETE语句都是隐式事务的一部分。即使只发出一条语句,也会把这条语句当做一个事务-要么执行语句中的所有内容,要么什么都不执行。但是如果需要的不只是一条,可能是多条语句呢?在这种情况下,就需要有一种方法来标记事务的开始和结束,以及事务的成功或失败。可以使用一些T-SQL语句在事务中”标记”这些点。

BEGIN TRAN:设置起始点。
COMMIT TRAN:使事务成为数据库中永久的、不可逆转的一部分。
ROLLBACK TRAN:本质上说想要忘记它曾经发生过。
SAVE TRAN:创建一个特定标记符,只允许部分回滚。
一、BEGIN TRAN
  事务的开始可能是事务过程中最容易理解的概念。它唯一的目的就是表示一个单元的开始。如果由于某种原因,不能或者不想提交事务,那么这就是所有数据库活动将要回滚的起点。也就是说,数据库会忽略这个起点之后的最终没有提交的所有语句。

  语法如下:

  BEGIN TRAN[SACTION] [ | ]
  [ WITH MARK [] ]
二、COMMIT TRAN
  事务的提交是一个事务的终点。当发出COMMIT TRAN命令时,可以认为该事务是持久的。也就是说,事务的影响现在是持久的并会持续,即使发生系统故障也不受影响(只要有备份或者数据库文件没有被物理破坏就行)。撤销已完成事务的唯一方法是发出一个新的事务。从功能上而言,该事务是对第一个事务的反转。

  COMMIT TRAN语法如下:

  COMMIT TRAN[SACTION] [ | ]
三、ROLLBACK TRAN
  ROLLBACK做的事情是回到起点。从关联的BEGIN语句开始发生的任何事情事实上都会被忘记。

  除了允许保存点外,ROLLBACK的语法看上去和BEGIN或COMMIT语句一样:

  ROLLBACK TRAN[SACTION] [ | | | ]
四、SAVE TRAN
  保存事务从本质上说就是创建书签(bookmark)。为书签建立一个名称,在建立了”书签”之后,可以在回滚中引用它。创建书签的好处是可以回滚到代码中的特定点上-只要为想要回滚到的那个保存点命名。

  语法如下:

  SAVE TRAN[SCATION] [ | ]
  下面整个示例,先来建一张表如下:
  这里写图片描述
  

<code class="hljs sql">
--==================================================
--作者:龚德辉
--用途:生成新版报价
--日期:2015-11-04
--==================================================
Create Proc UP_NewQuo
(
 @PricingCode as nvarchar(30),
 @NewPricingCode as  nvarchar(30)
)
--set @PricingCode=&#39;QT-150804-001&#39;
--set @NewPricingCode=&#39;QT-150804-001-1&#39;
as
begin

BEGIN TRAN Tran_NewVersion    --开始事务

DECLARE @tran_error int;
SET @tran_error = 0;
    BEGIN TRY 

            insert into Quo_Standardcost 
            SELECT    &#39;&#39;, ClientNo, ClientDes, ClientFullDes, [Description], PartNo, CurrencyCode, Rate, LabourCost, 
                            LabourRate, ProfitRate, TaxRate, Ismanufacture, qy, stype, Loss, CarryCostRate, CapitalOccupationRate, 
                            ManufacturingFlag, ManufacturingValue, ManufacturingRate, EngineerId, Engineer,@NewPricingCode , getdate(), Modifier, 
                            ModifyDate, [Priority], SaleRemark, PurRemark, RDRemark, FINRemark, IsSend, SendId, BusinessId, Qty, Amount, 
                            SubTotal, Scrap, MaterialCost, ManufacturingExpense, LaborCost, ProductionCost, TaxCost, CarryCost, Sales, MOQ1K, 
                            MOQ3K, [5K], [3K], [1K], ProjectNo
            FROM      Quo_Standardcost
            WHERE   (PricingCode = @PricingCode)

            insert into [Quo_Standardcostdetail]
            SELECT 
                   @NewPricingCode
                  ,[Description]
                  ,[Item]
                  ,[Spec]
                  ,[Usage]
                  ,[Unit]
                  ,[Currency]
                  ,[Remarks]
                  ,getdate()
                  ,[Modifier]
                  ,[ModifyDate]
                  ,[MOQ]
              FROM  [Quo_Standardcostdetail]
              WHERE   (PricingCode = @PricingCode)


        SET @tran_error = @tran_error + @@ERROR;
    END TRY

BEGIN CATCH
    PRINT &#39;出现异常,错误编号:&#39; + convert(varchar,error_number()) + &#39;,错误消息:&#39; + error_message()
    SET @tran_error = @tran_error + 1
END CATCH

IF(@tran_error > 0)
    BEGIN
        --执行出错,回滚事务
        ROLLBACK TRAN;
        PRINT &#39;生成新版失败,取消生成!&#39;;
    END
ELSE
    BEGIN
        --没有异常,提交事务
        COMMIT TRAN;
        PRINT &#39;生成新版成功!&#39;;
    END

end</code>
登入後複製
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1318
25
PHP教程
1269
29
C# 教程
1248
24
如何快速地把你的 Python 程式碼變成 API 如何快速地把你的 Python 程式碼變成 API Apr 14, 2023 pm 06:28 PM

提到API開發,你可能會想到DjangoRESTFramework,Flask,FastAPI,沒錯,它們完全可以用來寫API,不過,今天分享的這個框架可以讓你更快把現有的函數轉化為API,它就是Sanic 。 Sanic簡介Sanic[1],是Python3.7+Web伺服器和Web框架,旨在提高效能。它允許使用Python3.5中添加的async/await語法,這可以有效避免阻塞從而達到提升響應速度的目的。 Sanic致力於提供一種簡單且快速,集創建和啟動於一體的方法

Lock wait timeout exceeded; try restarting transaction - 如何解決MySQL報錯:事務等待逾時 Lock wait timeout exceeded; try restarting transaction - 如何解決MySQL報錯:事務等待逾時 Oct 05, 2023 am 08:46 AM

Lockwaittimeoutexceeded;tryrestartingtransaction-如何解決MySQL報錯:事務等待逾時在使用MySQL資料庫時,有時可能會遇到一個常見的錯誤:Lockwaittimeoutexceeded;tryrestartingtransaction,該錯誤表示事務等待逾時。這個錯誤通常發生在並且

PHP PDO教學:從基礎到精通的進階指南 PHP PDO教學:從基礎到精通的進階指南 Feb 19, 2024 pm 06:30 PM

1.PDO簡介PDO是PHP的擴充庫,它提供了一個物件導向的方式來操作資料庫。 PDO支援多種資料庫,包括Mysql、postgresql、oracle、SQLServer等。 PDO使開發人員能夠使用統一的api來操作不同的資料庫,這使得開發人員可以在不同的資料庫之間輕鬆切換。 2.PDO連接資料庫要使用PDO連接資料庫,首先需要建立一個PDO物件。 PDO物件的建構函式接收三個參數:資料庫類型、主機名稱、資料庫使用者名稱和密碼。例如,以下程式碼建立了一個連接到mysql資料庫的物件:$dsn="mysq

MySQL事務處理:自動提交與手動提交的區別 MySQL事務處理:自動提交與手動提交的區別 Mar 16, 2024 am 11:33 AM

MySQL事務處理:自動提交與手動提交的差異在MySQL資料庫中,事務是一組SQL語句的集合,要麼全部執行成功,要麼全部執行失敗,保證了資料的一致性和完整性。在MySQL中,事務可以分為自動提交和手動提交,其區別在於事務提交的時機以及對事務的控制範圍。以下將詳細介紹自動提交和手動提交的區別,並給出具體的程式碼範例來說明。一、自動提交在MySQL中,如果沒有顯示

Java資料庫連線如何處理事務和並發? Java資料庫連線如何處理事務和並發? Apr 16, 2024 am 11:42 AM

事務確保資料庫資料完整性,包括原子性、一致性、隔離性和持久性。 JDBC使用Connection介面提供交易控制(setAutoCommit、commit、rollback)。並發控制機制協調並發操作,使用鎖或樂觀/悲觀並發控制來實現事務隔離性,以防止資料不一致。

掌握 PHP PDO 的力量:進階查詢與更新 掌握 PHP PDO 的力量:進階查詢與更新 Feb 20, 2024 am 08:24 AM

PHP資料物件(PDO)擴充功能提供了與資料庫伺服器高效且物件導向的互動。其高級查詢和更新功能使開發人員能夠執行複雜的資料庫操作,從而提高效能和程式碼可維護性。本文將深入探討PDO的高階查詢與更新功能,引導您掌握其強大功能。進階查詢:使用佔位符和綁定參數佔位符和綁定參數是提高查詢效能和安全性的重要工具。佔位符使用問號(?)表示查詢中可替換的參數,而綁定參數則允許指定每個參數的資料類型和值。透過使用這些方法,您可以避免sql注入攻擊並提高效能,因為資料庫引擎可以提前最佳化查詢。 //使用佔位符$stmt=$

lambda 表達式的語法和結構有什麼特色? lambda 表達式的語法和結構有什麼特色? Apr 25, 2024 pm 01:12 PM

Lambda表達式是無名稱的匿名函數,其語法為:(parameter_list)->expression。它們具有匿名性、多樣性、柯里化和閉包等特徵。在實際應用中,Lambda表達式可用於簡潔地定義函數,如求和函數sum_lambda=lambdax,y:x+y,並透過map()函數應用於列表來進行求和操作。

MySQL事務的原理及應用場景 MySQL事務的原理及應用場景 Mar 02, 2024 am 09:51 AM

MySQL事務的原理及應用場景在資料庫系統中,事務是一組SQL操作的集合,這些操作要麼全部成功執行,要麼全部失敗回滾。 MySQL作為一種常用的關聯式資料庫管理系統,支援事務的特性,能夠確保資料庫中的資料在一致性、隔離性、持久性和原子性方面得到保證。本文將從MySQL事務的基本原理入手,介紹其應用場景,並提供具體的程式碼範例供讀者參考。 MySQL事務的原理:My

See all articles