SQL Server事務、視圖和索引

来源:http://www.cnblogs.com/gaofei-1/archive/2016/12/21/6208131.html
-Advertisement-
Play Games

廢話不多說,直接上乾貨 14:13:23 事務 概括:事務是一種機制,一個操作序列,包含一組資料庫操作命令,並且把所有的命令作為一個整體一起 向系統提交或撤銷操作 請求。 事務的特性: 1.原子性:事務是一個完整的操作,事務的各元素都是不可分的(原子的)。事務中的一組命令要麼都執行,要麼都不執 行。 ...


廢話不多說,直接上乾貨            14:13:23


事務

    概括:事務是一種機制,一個操作序列,包含一組資料庫操作命令,並且把所有的命令作為一個整體一起 向系統提交或撤銷操作

       請求。

         

    事務的特性:

         1.原子性:事務是一個完整的操作,事務的各元素都是不可分的(原子的)。事務中的一組命令要麼都執行,要麼都不執

        行。

       2.一致性:當事務完成時,數據必須處於一致狀態。也就是說,在事務開始之前,資料庫中存儲的數據處於一致狀態。在

        正在進行的事務中,數據可能處於不一致的狀態。但是,當事務成功完成時,數據必須再次回到已知的一致狀態。

       3.隔離性:對數據進行修改的所有併發事務是彼此隔離的,這表明事務必須是獨立的,它不應以任何方式依賴於或影響其

        他事務。

       4.持久性:事務的持久性指不管系統是否發生了故障,事務處理的結果都是永久的。

       以上四個特性簡稱“ACID”特性

     

    語法:

       1.開始事務:    begin transaction    這個語句顯式的標記一個事務的起始點。

       2.提交事務:    commit transaction   這個語句標誌一個事務成功結束。

       3.回滾(撤銷)事務:rollback transaction    清除自事務起始點至該語句所做的所有數據更新操作,將數據狀態回滾

        到事務開始之前。

    

    事務分類:

       1.顯式事務:用begin transaction明確指定事務的開始

       2.隱式事務:通過設置set implicit_transactions on語句,將隱式事務模式設置為打開。當以隱式事務操作時,不需要

        指定事務的開始,只要提交或回滾每個事務就行了,SQL Server在提交或回滾事務後自動啟動新事務。

       3.自動提交事務:SQL Server的預設模式。它將每條單獨的T-SQL語句看為一個事務,如果成功執行,就自動提交,否

        則自動回滾。

 

視圖

    概括:視圖是保存在資料庫中的select查詢,是另一種查看資料庫中一個或多個表中數據的方法。視圖是一種虛擬表,通常是作

       為來自一個或多個表的行或列的子集創建的。

 

    作用:

       1.篩選表中的行。

       2.防止未經許可的用戶訪問敏感數據。

       3.將多個物理數據表抽象為一個邏輯數據表。

    

    操作:

       1.創建語法:create view (視圖名字,多為view開頭)

              as

              <select 語句>

       2.刪除語法:drop view (視圖名字,多為view開頭)

       3.查詢視圖是否存在:exists(select * from sysobjects where name='(視圖名字,多為view開頭)')

       4.查看視圖數據:select 列名,列名 from (視圖名字,多為view開頭)

 

    註意事項:

       1.每個視圖中可以使用多個表。

       2.與查詢相似,一個視圖可以嵌套另一個視圖,但最好不要超過3層。

       3.視圖中的select語句不能包括以下幾種:

          a.order by子句,除非在select語句的選擇列表中也有一個top子句。

          b.into關鍵字。

          c.引用臨時表或表變數。

 

索引

    概括:索引是SQL serv編排數據的內部方法,是檢索表中數據的直接通道。

       索引頁是資料庫中存儲索引的數據頁。索引頁存放檢索數據行的關鍵字頁及該數據行的地址指針。

    

    作用:索引的作用是通過使用索引,大大提高資料庫的檢索速度,改善資料庫性能。

 

    分類:

       1.唯一索引:唯一索引不允許兩行具有相同的索引值。

       2.主鍵索引:在資料庫關係圖中為表定義一個主鍵將自動創建主鍵索引,主鍵索引是唯一索引的特殊類型。

       3.聚集索引:在聚集索引中,表中各行的物理順序與鍵值的邏輯(索引)順序相同。一個表只能有一個聚集索引。

       4.非聚集索引:非聚集索引建立在索引頁上,當查詢數據時可以從索引中找到記錄存放的位置。一個表可以有多個非聚集

        索引。

       5.複合索引:在創建索引時,並不是只能對其中一列創建索引,與創建主鍵一樣,可以將多個列組合作為索引,這種索引

        稱為複合索引。

       6.全文索引:全文索引時一種特殊類型的基於標記的功能性索引,由SQL Server中全文引擎服務創建和維護。

 

    語法:

       1.創建索引:create [unique] [clustered | nonclustered] index (索引名稱,多為index開頭)

              on (表名)((列名))

              [with fillfactor = x]

             介紹:unique指定唯一索引,可選。clustered | nonclustered指定是聚集索引還是非聚集索引,可

                選。fillfactor 表示填充因數,是一個0-100的值,指示索引頁填滿的空間所占的百分比。語法

                內的中括弧代表可選部分。

       2.刪除索引:drop index (表名).(索引名稱)

             註意事項:a.刪除表時,該表的所有索引將同時被刪除。

                  b.如果要刪除表的所有索引,則先要刪除非聚集索引,再刪除聚集索引。

 

 

 

--以上


ps:如有不正之處,歡迎提出。                      16:18:26

 


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

-Advertisement-
Play Games
更多相關文章
  • 本篇將對“1=3”“&5”這樣無法求值的不正確的表達式進行檢查。 將檢查如下這些問題。●為無法賦值的表達式賦值(例:1 = 2 + 2)●使用非法的函數名調用函數(例:"string"("%d\n", i))●操作數非法的數組引用(例:1[0])●操作數非法的成員引用(例:1.memb)●操作數非法 ...
  • 第一步: protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) ...
  • 一、文件保存數據介紹 Activity提供了openFileOutput()方法可以用於把數據輸出到文件中,具體的實現過程與在J2SE環境中保存數據到文件中是一樣的。文件可用來存放大量數據,如文本、圖書、音頻等。 File對象適合按照從開始到結束的順序不跳過地讀取或寫入大量數據。例如,它適合於圖片文 ...
  • 問題: 在和Unity交互的過程中,從Unity開發工具打包出來的項目文件,在添加AFNetworking庫,運行時報出以下錯誤: Undefined symbols for architecture armv7: "_kUTTagClassMIMEType", referenced from: - ...
  • 昨天上架到appStore的時候碰到個問題,構建好後上傳到itunesconnect的的包都用不了, 顯示錯誤為:此構建版本無效。 或者英文顯示為:ITC.apps.preReleaseBuild.errors.invalidBinary 由於和itunesconnect帳號綁定的郵箱暫時進不去,沒 ...
  • 本期內容包括: Google的物聯網平臺Android Things; FileProvider; Android Studio的Layout Preview使用; Retrofit2使用; Google Sign-In和SmartLock; 把敏感信息放入NDK的解決方式. 設計部分討論了調色板... ...
  • 使用快遞100查詢介面實現 源碼地址:https://github.com/chenjie200280/weizhang 測試安裝包:http://files.cnblogs.com/files/ttsofts/weizhang.apk 1.查詢界面 2.查詢結果1 (有違章的信息) 3.查詢結果3 ...
  • 很多人會遇到 初次運行 react native run android的時候 gradle下載極慢,甚至會失敗的問題 如下圖 實際上這個問題好解決的 1. 首先 把對應版本的 下載到本地任意一個磁碟里 比如說我在到了 2. 然後拖拽 文件夾到 瀏覽器 就會得到 的訪問地址 後面加上文件名 得到 的 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...