資料庫事務的基本概念

来源:https://www.cnblogs.com/klvchen/archive/2019/01/24/10312957.html
-Advertisement-
Play Games

事務的基本特性: 事務有4個非常重要的特性 (ACID) Atomicity(原子性) 事務是一個不可分割的整體,所有操作要麼全做,要麼全不做;只要事務中有一個操作出錯,回滾到事務開始前的狀態的話,那麼之前已經執行的所有操作都是無效的,都應該回滾到開始前的狀態。 Consistency(一致性) 事 ...


事務的基本特性:
事務有4個非常重要的特性 --- (ACID)

Atomicity(原子性)
事務是一個不可分割的整體,所有操作要麼全做,要麼全不做;只要事務中有一個操作出錯,回滾到事務開始前的狀態的話,那麼之前已經執行的所有操作都是無效的,都應該回滾到開始前的狀態。

Consistency(一致性)
事務執行前後,數據從一個狀態到另一個狀態必須是一致的,比如A向B轉賬(A、B的總金額就是一個一致性狀態),不可能出現A扣了錢,B卻沒收到的情況發生。

Isolation(隔離性)
多個併發事務之間相互隔離,不能互相干擾。關於事務的隔離性,可能不是特別好理解,這裡的併發事務是指兩個事務操作了同一份數據的情況;而對於併發事務操作同一份數據的隔離性問題,則是要求不能出現臟讀、幻讀的情況,即事務A不能讀取事務B還沒有提交的數據,或者在事務A讀取數據進行更新操作時,不允許事務B率先更新掉這條數據。而為瞭解決這個問題,常用的手段就是加鎖了,對於資料庫來說就是通過資料庫的相關鎖機制來保證。

Durablity(持久性)
事務完成後,對資料庫的更改是永久保存的,不能回滾。


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

-Advertisement-
Play Games
更多相關文章
  • 背景描述 問題分析 Q1:為什麼會產生臨時表? 這個不多說,SQL寫的惹不起,反正就是半個小時看不懂的那種,就是一眼就知道一定會產生臨時表的😂~~~ Q2:登錄到機器上去查看記憶體使用偏小? 因為這個物理機的記憶體是125G,但是mysql的總數據量不超過1G,所有實際並不需要多少記憶體就可以將所有數據 ...
  • 1.下載壓縮包,地址1(官網下載):https://www.mysql.com/downloads/ 地址2(百度網盤):https://pan.baidu.com/s/12lnpcr3thBe9k-6CyxvHeg 提取碼: j9ya 官網下載方法如下: 2.解壓壓縮包到自己喜歡的文件夾中;(以我 ...
  • 前言 java連接資料庫完整流程為: 1,獲得驅動(driver),資料庫連接(url),用戶名(username),密碼(password)基本信息的三種方式。 2,通過獲得的信息完成JDBC實現連接資料庫。 註:連接前請導入jar包,例:連接mysql資料庫需要導入mysql-connector ...
  • JDBC全稱為:Java Data Base Connectivity (java資料庫連接),主要用於java與資料庫的鏈接。 整個鏈接過程如下圖: 1.資料庫驅動:Driver 載入mysql驅動:Class.forName("com.mysql.jdbc.Driver"); 載入oracle驅 ...
  • 備註: 直接使用Count(*)或Count(1)這些大家基本都會,主要是Count函數還可以加滿足表達式的統計:express 關於Count函數表達式的用法,目前個人只知道2種: a:使用:Count(表達式 Or null) b:使用:Count(Case when 表達式 then 1 E... ...
  • 網有很多相關內容,我在此做記錄和總結 1、主要是sql server 配置管理工具的配置 在此參考 https://www.cnblogs.com/yougmi/p/4616273.html(再次感謝!) (1)打開 sqlserver配置管理器 (2)三處配置,一處重啟: 一處配置: 二處配置: ...
  • 最近在跟著一個大佬學習Hadoop底層源碼及架構等知識點,覺得有必要記錄下來這個學習過程。想到了這個廢棄已久的blog賬號,決定重新開始更新。 主要分以下幾步來進行源碼學習: 一、搭建源碼閱讀環境二、源碼項目結構概覽及hdfs源碼包結構簡介三、NameNode介紹 第一步,搭建源碼閱讀環境。 把Ha ...
  • 根據網上安裝教程,簡單總結如下: 1.去mongodb官網下載電腦系統對應版本的軟體,比如我的是windows 64位的,就選擇64位的,可能下載下來之後文件夾上面顯示的是win32,這個不用理會; 2.把該目錄放到自己對應放軟體的盤下,我放在了d盤; 3.在mongodb文件夾目錄下新建data文 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...