【資料庫概論】第五章 資料庫完整性

来源:https://www.cnblogs.com/cyra/archive/2023/12/06/17878911.html
-Advertisement-
Play Games

資料庫完整性包括正確性和相容性,DBMS通過提供約束條件機制、檢查方法和違約處理功能維護資料庫完整性,其中實體完整性通過主鍵確保唯一標識,參照實體性通過外鍵關聯,用戶定義完整性滿足特定應用需求,而觸發器和斷言提供事件驅動和複雜約束支持,共同構成資料庫保持一致性的關鍵機制。 ...


資料庫的完整性指的是數據的正確性和相融性。數據的正確性是指符合現實世界語意、反映當前實際情況;數據的相容性指的是資料庫對同一對象在不同關係表中的數據是符合邏輯的,比如學生的學號一定是唯一的,學生所屬的專業一定是專業表中有的專業等,數據的完整性主要是防止資料庫中出現不合語義的數據。為了維護資料庫的完整性,DBMS 需要實現以下功能:

  1. 提供定義完整性約束條件的機制
    完整性約束條件又稱完整性規則,是資料庫中的數據必須滿足的語意約束條件。表達了給定數據模型中數據以及其聯繫具有的約束和依存規則,如主鍵和外鍵。

  2. 提供完整性檢查的方法
    DBMS 檢查數據是否滿足完整性約束條件的機制稱為完整性檢查,一般會在插入、更新和刪除操作後開始執行檢查。

  3. 進行違約處理
    DBMS 如果發現用戶操作違背了完整性約束將會採取一定動作,比如拒絕(NO ACTION)此操作或者級聯(CASCADE)執行其他操作。

關係型資料庫管理系統使得完整性控制稱為其核心支持的功能,從而能夠為所有用戶和應用提供一致的資料庫完整性。

5.1 實體完整性

關係模型的實體完整性在 CREATE TABLE 中使用 PRIMARY KEY 定義。實體完整性指的是是否能夠唯一的區分出一個實體,因此 PRIMARY KEY 是用於唯一標識一個實體的符號,如同人的身份證一般。PRIMARY KEY 可以只使用一個屬性作為主鍵,也可以將多個屬性設置為主鍵。

使用了 PRIMARY KEY 定義主碼之後,對基本表進行更新或者插入操作的時候,就會執行實體完整性規則檢查,包括:

  • 檢查主碼值是否唯一,不唯一則拒絕操作
  • 檢查主碼的各個屬性是否為空,只要有某一行的屬性為空就拒絕修改
  • 檢查主碼是否為空的唯一方法就是進行全表掃描,判斷是否有重覆的主碼。但是遍歷的性能很低,因此 DBMS 會在主碼上自動建立一個索引,比如 B+ 樹索引,通過索引查找基本表中是否存在新的主碼值,這樣會大大提高效率。

5.2 參照實體性

關係模型的參照完整性在 CREATE TABLE 中用 FOREIGN KEY 來定義哪些列為外碼,用 REFERENCES 短語指明這些外碼參照哪些表的主碼。

在表級定義完整性

參照完整性將兩個表中的相應元組聯繫起來了,因此對被參照表和參照表進行 CRUD 時可能會破壞參照完整性,必須進行檢查以保證這兩個表數據的一致性。

比如:

可能破壞參照完整性的情況及違約處理

當發生不一致的情況,一般有以下三種處理策略:

  • 拒絕(NO ACTION)執行:不允許該語句執行,這是預設策略
  • 級聯(CASCADE):假設刪除或者修改被參照表的一個元組導致參照表不一致時,刪除或者修改參照表中所有導致不一致的元組。比如刪除了學生表中的一個學生,則順帶在選課表表中刪除該學生的所有選課信息。
  • 設為空值:可以將被參考表不一致的數據暫時置為空值,比如刪除了班級表中的一個班級,然後在學生表中將該班級的所有學生的班級信息都變為空值,等待重新分班。該策略要註意:參照表中的的列需要設置為允許空值。

5.3 用戶定義的完整性

用戶定義的完整性就是針對某一具體應用的數據必須滿足的語義要求。目前 DBMS 都提供了定義和檢驗這類完整性的機制。

5.3.1 屬性上的約束條件

在 CREATE TABLE 定義屬性的同時,可以根據應用要求定義屬性上的約束條件,也就是屬性值限制,包括:

  • 列值非空(NOT NULL)
  • 列值唯一(UNIQUE)
  • 檢查列值是否滿足一個條件表達式(CHECK 短語)

使用例子如下:

CREATE TABLE Student  
(Sno CHAR(9) PRIMARY KEY,  
Ssex CHAR(2) CHECK (Ssex IN ('m', 'f')) -- 性別隻能是男或者女

如果不滿足屬性約束條件,會被直接拒絕執行

5.3.2 元組上的約束條件

元組上的約束條件定義和屬性約束條件定義類型,在 CREATE TABLE 語句中可以使用 CHECK 短語定義元組上的約束條件。元組級的約束條件可以設置不同屬性取值的相互約束條件。

-- 學生性別為男的時

候,名字不能以Ms.打頭  
CREATE TABLE Student  
(Sno CHAR(9) PRIMARY KEY,  
Sname CHAR(8) NOT NULL,  
Ssex CHAR(2),  
CHECK (Ssex='f' OR Sname NOT LIKE 'Ms.%'));

如果不滿足元組約束條件規則,會被直接拒絕執行

5.4 完整性約束命名子句

SQL 在 CREATE TABLE 語句中提供了完整性約束命名子句 CONSTRAINT,用來對完整性約束條件命名,從而可以更靈活的增加、刪除一個完整性約束條件,格式如下:

CONSTRAINT <完整性約束條件名><完整性約束條件>

其中的完整性約束條件包括 NOT NULL, UNIQUE, PRIMARY KEY, FOREIGN KEY, CHECK 短語等等。通過給約束命名,我們可以很方便的修改完整性,比如:

ALTER TABLE Student DROP CONSTRAINT C4; -- 去除 Student 表中的 C4 約束

ALTER TABLE Student ADD CONSTRAINT C1 CHECK (Sno BETWEEN 9000 AND 9999); -- 新增 C1 約束

5.5 域中的完整性限制

5.6 斷言

當一個約束涉及 2 個(或)更多的表時,表約束機制有時很難,結果可能不會如預期的那樣。為了涵蓋這種情況,SQL 支持創建斷言,這些斷言是不與一張表關聯的約束。斷言語句應確保資料庫中始終存在某個條件。每當在相應的表中進行修改時,DBMS 總是檢查斷言。

在 SQL 中可以使用 CREATE ASSERTION 語句,通過聲明性斷言來指定更具一般性的約束。可以定義涉及多個表或者聚集操作的比較複雜的完整性約束。斷言創建後,任何對斷言中所涉及到的關係的操作都會觸發關係資料庫對斷言的檢查,任何使斷言不為真的操作都會被拒絕執行。

一般使用如下語句創建斷言:

CREATE ASSERTION <斷言名><CHECK子句>

每個斷言都會被賦予一個名字,CHECK 子句中的約束條件和 WHERE 子句的條件表達式類似。

-- 限制資料庫課程最多60名學生選修  
CREATE ASSERTION ASSE_SC_DB_SUM CHECK (60 >= (SELECT COUNT(*) FROM Course, SC WHERE SC.Cno = Course.Cno AND Course.Cname = '資料庫'));

每當往 SC 表中插入一條元組,該斷言就會被觸發。一旦人數超過 60 人,CHECK 子句就會返回 false 值。

刪除斷言只需要使用 DROP ASSERTION <斷言名>

5.7 觸發器(Trigger)

觸發器是用戶定義在關係表上的一類由事件驅動的特殊過程。用戶的對應操作會觸發觸發器,而觸發器則會執行相應的操作。

5.7.1 定義觸發器

觸發器又叫做事件——條件——動作規則。當特定的系統事件發生的時候,則會對規則的條件進行檢查。創建觸發器的指令如下:

CREATE TRIGGER <觸發器名>  
{BEFORE|AFTER} <觸發事件> ON <表名>  
REFERENCING NEW|OLD ROW AS <變數>  
FOR EACH{ROW|STATEMENT}  
[WHEN <觸發條件>] <觸發動作體>
  • 只有表的擁有者,才可以在表上創建觸發器,並且一個表上只能創建一定數量的觸發器
  • 觸發器名可以包含模式名。同一模式下,觸發器名必須是唯一的,並且觸發器名和表名需要在同一模式下。
  • 觸發器只能定義在基本表上,不能定義在視圖上。
  • 觸發事件可以是 INSTER\DELETE\UPDATE 和這幾個事件的組合。AFTER、BEFORE 指明瞭觸發的時機,是執行前還是執行後觸發。
  • 觸發器類型可以被分為行級觸發器(FOR EACH ROW)和語句級觸發器(FOR EACH STATEMENT)。假設表 Teacher 有 1000 行,執行 UPDATE Teacher SET Deptno=5,如果是語句級觸發器,則執行完語句後執行一次;如果是行級觸發器,則會執行 1000 次觸發體。
  • 觸發條件:觸發器被激活是,只有觸發條件為真觸發動作體才會開始執行
  • 觸發動作體:

觸發動作體指的是觸發觸發器後執行的動作。觸發動作體可以是一個匿名的 PL/SQL 過程塊,也可以是對已經創建存儲過程的調用。如果觸發動作體執行失敗,則激活觸發器的事件會終止執行。

5.7.2 激活觸發器

5.7.3 刪除觸發器

使用

DROP TRIGGER <觸發器名> ON <表名>

刪除觸發器

5.7.4 斷言和觸發器的區別

編號 斷言 觸發器
1 當知道給定的特定條件總是為真時,可以使用斷言。 即使特定條件可能是也可能不是,可以使用觸發器
2 當SQL條件不滿足時,整個表甚至資料庫都有可能被鎖定。 如果查詢條件不成立,觸發器可以捕獲錯誤。
3 斷言沒有鏈接到特定的表或事件。它執行用戶指定或定義的任務。 它有助於維護資料庫表中的完整性約束,尤其是在未定義主鍵和外鍵約束時。
4 斷言不維護對錶中所做更改的任何跟蹤。 觸發器跟蹤表中發生的所有更改。
5 與觸發器相比,斷言的語法更小。 它們有很大的語法來指示創建的觸發器的每一個特定的。
6 現代資料庫不使用斷言。 觸發器在現代資料庫中得到了很好的應用。

斷言不能修改數據,它們不鏈接到資料庫中的任何特定表或事件,但觸發器更強大,因為它們可以檢查條件並修改資料庫內表中的數據,這與斷言不同。


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

-Advertisement-
Play Games
更多相關文章
  • .net平臺使用SDK快速對接各大語言模型 1.項目介紹 最近,在做GPT項目時,發現各個平臺的介面規範和參數不同,需要根據不同平臺和模型寫多種介面,比較麻煩,不想Python那樣有豐富和方便的AI環境, 如果c#有一個SDK可以方便調用各種平臺模型就好了,這是AllInAI.Sharp.API萌芽 ...
  • WPF應用中,控制項本身也可以通過實現事件代碼實現拖動的處理,不過如果我們使用GongSolutions.WPF.DragDrop來處理,事情會變得更加簡單輕鬆,它支持很多控制項的拖動處理,如ListBox, ListView, TreeView, DataGrid等源自ItemsControl的控制項,... ...
  • 一、條件 1、windows server主機一臺,我是windows server 2019(當然windows10或者10月份5日更新的windows11也是可以行的)。 2、SQL Sever,我用的是SQL Server2019。 3、Power BI Report Server預設位置安裝 ...
  • Parallel.ForEach Parallel.ForEach 是一個用於在集合上並行執行迭代操作的強大工具。它通過有效地利用多核處理器的能力來提高性能。Parallel.ForEach 不僅能夠簡化並行編程,而且它在執行簡單迴圈時可以提供比傳統迭代更好的性能。 下麵是一個簡單的示例,演示瞭如何 ...
  • 版本 Linux 6.5 背景 在學習cgroupv2的時候,想給子cgroup開啟cpu控制器結果失敗了: # 查看可以開啟哪些控制器 root@ubuntu-vm:/sys/fs/cgroup# cat cgroup.controllers cpuset cpu io memory hugetl ...
  • 使用 ssh-keygen 生成密鑰 參考資料 https://learn.microsoft.com/zh-cn/azure/virtual-machines/linux/create-ssh-keys-detailed 快速開始 以下 ssh-keygen 命令預設在 ~/.ssh 目錄中生成 ...
  • 家中有閑置的小新,是A卡正好合適裝linux 安裝前 關閉安全引導 通過關機鍵旁邊的重置口重新開機 OR 在開機界面按F2(開啟Hotkey 模式的要按Fn+F2) 進入BIOS 設置界面,關閉Secure Boot,這樣方便安裝linux 系統刻錄 linux有很多發行版 大家可以自行選擇,推薦U ...
  • ssh介紹 SSH,全稱為Secure Shell,是一種用於在網路中安全地進行遠程登錄和執行命令的協議。它通過加密的方式提供了對網路通信的保護,使得用戶可以在不安全的網路環境下安全地進行遠程管理和數據傳輸。 以下是 SSH 協議的一些重要特點和功能: 安全性:SSH 使用加密技術來保護數據在網路中 ...
一周排行
    -Advertisement-
    Play Games
  • 1、預覽地址:http://139.155.137.144:9012 2、qq群:801913255 一、前言 隨著網路的發展,企業對於信息系統數據的保密工作愈發重視,不同身份、角色對於數據的訪問許可權都應該大相徑庭。 列如 1、不同登錄人員對一個數據列表的可見度是不一樣的,如數據列、數據行、數據按鈕 ...
  • 前言 上一篇文章寫瞭如何使用RabbitMQ做個簡單的發送郵件項目,然後評論也是比較多,也是準備去學習一下如何確保RabbitMQ的消息可靠性,但是由於時間原因,先來說說設計模式中的簡單工廠模式吧! 在瞭解簡單工廠模式之前,我們要知道C#是一款面向對象的高級程式語言。它有3大特性,封裝、繼承、多態。 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 介紹 Nodify是一個WPF基於節點的編輯器控制項,其中包含一系列節點、連接和連接器組件,旨在簡化構建基於節點的工具的過程 ...
  • 創建一個webapi項目做測試使用。 創建新控制器,搭建一個基礎框架,包括獲取當天日期、wiki的請求地址等 創建一個Http請求幫助類以及方法,用於獲取指定URL的信息 使用http請求訪問指定url,先運行一下,看看返回的內容。內容如圖右邊所示,實際上是一個Json數據。我們主要解析 大事記 部 ...
  • 最近在不少自媒體上看到有關.NET與C#的資訊與評價,感覺大家對.NET與C#還是不太瞭解,尤其是對2016年6月發佈的跨平臺.NET Core 1.0,更是知之甚少。在考慮一番之後,還是決定寫點東西總結一下,也回顧一下.NET的發展歷史。 首先,你沒看錯,.NET是跨平臺的,可以在Windows、 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 添加節點(nodes) 通過上一篇我們已經創建好了編輯器實例現在我們為編輯器添加一個節點 添加model和viewmode ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...
  • 類型檢查和轉換:當你需要檢查對象是否為特定類型,並且希望在同一時間內將其轉換為那個類型時,模式匹配提供了一種更簡潔的方式來完成這一任務,避免了使用傳統的as和is操作符後還需要進行額外的null檢查。 複雜條件邏輯:在處理複雜的條件邏輯時,特別是涉及到多個條件和類型的情況下,使用模式匹配可以使代碼更 ...
  • 在日常開發中,我們經常需要和文件打交道,特別是桌面開發,有時候就會需要載入大批量的文件,而且可能還會存在部分文件缺失的情況,那麼如何才能快速的判斷文件是否存在呢?如果處理不當的,且文件數量比較多的時候,可能會造成卡頓等情況,進而影響程式的使用體驗。今天就以一個簡單的小例子,簡述兩種不同的判斷文件是否... ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...