MSSQL 事務,視圖,索引,存儲過程,觸發器

来源:http://www.cnblogs.com/Aaxuan/archive/2016/12/28/6219080.html
-Advertisement-
Play Games

事務 事務是一種機制、是一種操作序列,它包含了一組資料庫操作命令,這組命令要麼全部執行,要麼全部不執行。 在資料庫系統上執行併發操作時事務是作為最小的控制單元來使用的。這特別適用於多用戶同時操作的數據通信系統。例如:訂票、銀行、保險公司以及證券交易系統等。 如果某一事務成功,則在該事務中進行的所有數 ...


 

事務

 

事務是一種機制、是一種操作序列,它包含了一組資料庫操作命令,這組命令要麼全部執行,要麼全部不執行。

在資料庫系統上執行併發操作時事務是作為最小的控制單元來使用的。這特別適用於多用戶同時操作的數據通信系統。例如:訂票、銀行、保險公司以及證券交易系統等。

如果某一事務成功,則在該事務中進行的所有數據修改均會提交,成為資料庫的永久組成部分,如果事務遇到錯誤且必須取消或回滾,則所有數據修改均會被清除。

開始事務  BEGIN TRANSACTION

提交事務  COMMIT TRANSACTION

回滾事務  ROLLBACK TRANSACTION

 

--開始事務
begin transaction
declare @errorSum int    --定義變數,用於累計事務執行過程中的錯誤
--轉帳
update bank set currentMoney=currentMoney-800 where customerName='張三'
set @errorSum=@errorSum+@@error  --累計是否有錯誤
update bank set currentMoney=currentMoney+800 where customerName='李四'
set @errorSum=@errorSum+@@error  --累計是否有錯誤

print '查看轉帳事務過程中的餘額'
select * from bank

--根據是否有錯誤,確定事務是提交還是回滾
if @errorSum>0
    begin
        print '交易失敗,回滾事務.'
        rollback transaction
    end
else
    begin
        print '交易成功,提交事務,寫入硬碟,永久保存!'
        commit transaction
    end
go

 

索引

 

索引提供指向存儲在表的指定列中的數據值的指針,然後根據指定的順序對這些指針排序。

索引使資料庫程式無需對整個表進行掃描,就可以在其中找到所需數據。

索引依賴於資料庫的表,作為表的一個組成部分,一旦創建後,又資料庫系統自身進行維護。

 

視圖

 

視圖和表類似,是一張虛擬表,通常是作為一個或多個表的行或列的子集創建的,視圖只供查詢,數據不可更改,查詢數據來源於我們建立的實體表。

 

存儲過程

 

存儲過程的概念類似於函數,它是SQL語句和控制流語句的預編譯集合。

存儲過程存儲在資料庫內,可由應用程式調用。

存儲過程的優點顯而易見:封裝複雜操作,節省編譯優化時間,實現代碼重用。

 

CREATE PROC 存儲過程名

AS

BEGIN

SET NOCOUNT ON

--SQL語句

END

 

帶有輸出參數的存儲過程,如果參數後面帶有output,則表示此參數為輸出參數,否則是普通的輸入參數,輸入參數可以帶有預設值

CREATE PROC 存儲過程名

@變數名 數據格式[=預設值] [OUTPUT]

AS

BEGIN

SET NOCOUNT ON

--SQL語句

END

 

調用存儲過程:EXEC  存儲過程名 [參數]

 

--調用後返回通過考試的學生人數,以供其他sql語句調用

CREATE PROCEDURE proc_withOutputpara

@subject varchar(10)='SQL',  --接受參數,帶預設參數,變數之間帶逗號

@count int output  --輸出參數

AS

SELECT @count=count(*) FROM students S,Mark SC,course C

WHERE S.sID=SC.sID AND SC.cID=C.cID

AND C.cNAME='C#' AND SC.SCore<60

GO

 

--調用存儲過程

DECLARE @count int,@sub varchar(10)  --聲明變數

SET @sub='C#'

EXEC  proc_withOutputpara @sub,@count=@count output

PRINT @sub+'考試不及格的共有'+convert(varchar(2),@count)+'人'

GO

 

 

觸發器

 

觸發器是一種特殊類型的存儲過程。

觸發器是當對某一個表進行操作。諸如:update、insert、delete這些操作的時候,系統會自動調用執行該表上對應的觸發器。

觸發器的主要作用是實現由主鍵和外鍵所不能保證的複雜的參照完整性和數據的一致性。

 

CREATE TRIGGER 觸發器名稱

ON 表名

FOR insert/delete/update

AS

--SQL語句

GO

 

博客園hoojo博主關於觸發器的詳細介紹:http://www.cnblogs.com/hoojo/archive/2011/07/20/2111316.html

 

博主初學,有錯還望各位大神指出。

轉載請聯繫


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、Node:節點元素節點->HTML標簽文本節點->文字 但是在標準瀏覽器(除了IE6~8)中會把空格和換行都當做文本節點來處理註釋節點->註釋document2、節點的特征元素節點:nodeType->1 nodeName->大寫的標簽名 nodeValue->null文本節點:nodeType ...
  • 昨天工作時候發現一個bug,是關於a標簽的,在安卓客戶端中,如果是a標簽的話,長按會出現一個彈框,如圖所示 是因為安卓客戶端的長按觸發機制,以後進行wap端開發的時候,如果用到跳轉頁面儘量不要用a標簽,取而代之可以用別的標簽+onclick=“window.location.href='';”的方式 ...
  • UIWebView是iOS最常用的SDK之一,它有一個stringByEvaluatingJavaScriptFromString方法可以將javascript嵌 入頁面中,通過這個方法我們可以在iOS中與UIWebView中的網頁元素交互。 stringByEvaluatingJavaScript ...
  • 幀動畫> 一張張圖片不斷的切換,形成動畫效果* 在drawable目錄下定義xml文件,子節點為animation-list,在這裡定義要顯示的圖片和每張圖片的顯示時長 <animation-list xmlns:android="http://schemas.android.com/apk/res ...
  • iOS開發小技巧 - 中文排序NSString 與 UnicodeObjective-C 中文 按拼音全排序 ...
  • 一、實現思路 1、在build.gradle中添加依賴,例如: 也可以將support-v4替換為appcompat-v7,例如: 因為appcompat-v7是依賴於support-v4的。 更多說明可參考官方文檔support library部分。 2、在xml中添加TabLayout和View ...
  •   任何一款直播軟體都必須進行美顏,不然哪來的那麼多美女,所以技術改變世界,不只是說說而已。美顏在採集的時候就得就行,讓主播實時看到直播的效果。 1.美顏原理   其實美顏的本質就是美白和磨皮,分別通過提高亮度和模糊像素點進行。我們一般用GPUImage這個開 ...
  • 一資料庫伺服器(SQL Server 2014)上的一個作業執行報錯,具體錯誤信息如下: Executed as user: NT SERVICE\SQLSERVERAGENT. 用戶 'xxxx\xxxxx$' 登錄失敗。 [SQLSTATE 28000] (Error 18456). The s... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...