數據庫-第四/五章 數據庫安全性和完整性【期末復習|考研復習】

前言

總結整理不易,希望大家點贊收藏。

給大家整理了一下計數據庫系統概論中的重點概念,以供大家期末復習和考研復習的時候使用。
參考資料是王珊老師和薩師煊老師的數據庫系統概論(第五版)。


文章目錄

  • 前言
  • 4 第四章 數據庫安全性
    • 4.1 數據庫安全性定義
    • 4.2 數據庫不安全因素
    • 4.3 安全性控制
      • 4.3.1 sql控制
    • 4.4 數據庫角色
  • 5 第五章 數據庫完整性
    • 5.1 數據庫完整性
    • 5.2 完整性約束
      • 5.2.1實體完整性(主鍵):
      • 5.2.2 用戶定義完整性:
      • 5.2.3 例子
    • 5.3 斷言(更一般性的約束)
    • 5.4 觸發器
      • 5.4.1 A. 創建觸發器
      • 5.4.2 B. 行級觸發器
      • 5.4.3 C. 刪除觸發器
  • 6 練手題


4 第四章 數據庫安全性

4.1 數據庫安全性定義

數據庫的安全性指的是保護數據庫以防止不合法使用造成的數據泄露、更改、破壞。

4.2 數據庫不安全因素

(1) 非授權用戶對數據庫的惡意存取和破壞
(2) 敏感數據泄露
(3) 環境脆弱

4.3 安全性控制

(1) 用戶身份鑒別:靜態口令(密碼),動態口令(驗證碼),生物特征(指紋,人臉),智能卡。
(2) 存取控制:自主存取控制:grant,revoke語句。通過對存取權限的設定來進行安全性控制,對數據本身沒有安全性標記。
強制存取控制:對數據本身進行密級標記,無論數據怎么復制,標記和數據總是一體的。只有符合密級標記要求的用戶才能操縱數據。適用于安全性要求較高的場合。
(3) 視圖
(4) 審計:一種事后檢查的方式,審計把用戶對數據庫的所有操作自動記錄放在審計日記里。用于安全性檢查。

4.3.1 sql控制

Grant語句:

Grant select on table student To U1 With grant option  //允許U1授權給其他用戶

REVOKE語句:

Revoke insert On table sc From u1 (cascade/restrict) //cascade 級聯收回U1授權出去的所有權限 Restrict 拒絕操作

創建數據庫用戶:

Create user u1 with DBA/RESOURCE/CONNECT //創建數據庫模式的權限在創建數據庫用戶的時候才授權

DBA:所有權限 CONNECT只能登陸查詢和操縱,不能創建別的東西 RESOURCE 可以創建表和查詢、操縱。不能創建用戶和模式 (默認connect)

4.4 數據庫角色

角色使權限的合集,一般為具有相同權限的用戶創建一個角色。
創建

Create role r1

授權 和給用戶授權一樣,可以給角色授權其他角色和用戶:

Grant 角色1,角色2 To 角色3 With admin option

收回權限 和用戶一樣

5 第五章 數據庫完整性

5.1 數據庫完整性

定義:是指數據的正確性和相容性。是為了防止不符合語義的,不正確的數據。
為了為維護數據庫的完整性,DBMS必須實現:
(1)完整性約束機制
(2)完整性檢查方法
(3)進行違約處理

5.2 完整性約束

5.2.1實體完整性(主鍵):

列級約束,表級約束。主碼唯一,且非空。
全表掃描 Primary key();
參照完整性(外鍵):Foreign key(sno) references student(sno);
參照正確,存在。非空(因為參照主碼啊)

5.2.2 用戶定義完整性:

A. 屬性上的約束條件 Not null(非空) Unique(唯一) Check語句:sex char(2) check (sex in (‘男’,‘女‘)); 違約就拒絕執行
B. 元組上的約束條件,可以設置不同屬性之間的相互制約 Check (sex=’女’ or name not like ‘Ms.%’)

5.2.3 例子

完整性約束命名子句

Constraint c1 check (sex in (‘男’,‘女‘))//C1是約束名
Constraint c2 primary key (sno);

完整性約束都是在create table/alter table的時候寫 Alter table student Add constraint c3 check(age<20)

5.3 斷言(更一般性的約束)

//限制數據庫最多60個人選
創建

Create assertion ass_st Check(60>=( Select count(*) From course,scWhere course.cno=sc.cno and cname=’數據庫’))

刪除

Drop assertion ass_st

5.4 觸發器

定義:觸發器是用戶定義在關系表上的一類由事件驅動的特殊過程。事件——條件——動作,當事件發生時,檢查條件,條件符合就執行。
觸發器分為insert,update,delete三種觸發器

5.4.1 A. 創建觸發器

Create trigger t1 Before/after select/update/insert ( of sname 指定哪一列) on student
Referencing new/old row as R1 (給新的、舊的行取個名字,方便下面操作) For each row/statement When (條件) 觸發體

例:

create trigger t1 After update of grade on sc Referencing Old row as oldtuple New row as newtuple
For each row When (newtuple.grade>=1.1* oldtuple.grade)
Insert into sc_u(sno,cno,oldgrade,newgrade) Values(oldtuple.sno,oldtuple.cno,oldtuple.grade,newtuple.grade)

5.4.2 B. 行級觸發器

For each row 當觸發器事件發生,表有多少行,就執行多少次觸發器動作體
語句級觸發器
For each statement 當觸發器事件發生,只執行一次

5.4.3 C. 刪除觸發器

Drop trigger 觸發器 on 表名

6 練手題

數據庫不好找題,都是很零碎的知識點,還是要多記概念,SQL語句相對來說并不是很重要

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/714898.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/714898.shtml
英文地址,請注明出處:http://en.pswp.cn/news/714898.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

學生宿舍管理小程序|基于微信小程序的學生宿舍管理系統設計與實現(源碼+數據庫+文檔)

學生宿舍管理小程序目錄 目錄 基于微信小程序的學生宿舍管理系統設計與實現 一、前言 二、系統功能設計 三、系統實現 1、管理員模塊的實現 &#xff08;1&#xff09;學生信息管理 &#xff08;2&#xff09;公告信息管理 &#xff08;3&#xff09;宿舍信息管理 &am…

git clone http/https 報錯 10054/443 問題

文章目錄 錯誤解決方案1 關閉http和https代理2 設置自己的代理 錯誤 錯誤 Failed to connect to github.com port 443: Timed out OpenSSL SSL_read: Connection was reset, errno 10054 一般都是網絡問題 解決方案 1 關閉http和https代理 git config --global --unset htt…

《系統架構設計師教程(第2版)》第5章-軟件工程基礎知識-05-凈室軟件工程(CSE)

文章目錄 1. 概述2. 理論基礎2.1 函數理論2.2 抽樣理論 3. 技術手段3.1 增量式開發3.2 基于函數的規范與設計3.3 正確性驗證3.4 統計測試 (Statistically Based Testing) 和軟件認證 4. 應用與缺點1&#xff09;太理論化2&#xff09;缺少傳統模塊測試3&#xff09;帶有傳統軟件…

UE學習筆記--解決滾輪無法放大藍圖、Panel等

我們發現有時候創建藍圖之后&#xff0c;右上角的縮放是1&#xff1a;1 但是有時候我們可能需要放的更大一點。 發現一直用鼠標滾輪像上滾動&#xff0c;都沒有效果。 好像最大只能 1&#xff1a;1. 那是因為 UE 做了限制。如果希望繼續放大&#xff0c;我們可以按住 Ctrl 再去…

StarRocks實戰——攜程酒店實時數倉

目錄 一、實時數倉 二、實時數倉架構介紹 2.1 Lambda架構 2.2 Kappa架構 三、攜程酒店實時數倉架構 3.1 架構選型 3.2 實時計算引擎選型 3.3 OLAP選型 四、攜程酒店實時訂單 4.1 數據源 4.2 ETL數據處理 4.3 應用效果 4.4 總結 原文大佬的這篇實時數倉建設案例有借…

【計算機網絡_應用層】TCP應用與相關API守護進程

需要云服務器等云產品來學習Linux的同學可以移步/–>騰訊云<–/官網&#xff0c;輕量型云服務器低至112元/年&#xff0c;優惠多多。&#xff08;聯系我有折扣哦&#xff09; 文章目錄 1. 相關使用接口2. 代碼實現2.1 日志組件2.2 Server端2.3 Client端2.3 bug解決 3. 守…

什么是依賴注入(Dependency Injection)?它在 C++ 中是如何實現的?

什么是依賴注入&#xff08;Dependency Injection&#xff09;&#xff1f;它在 C 中是如何實現的&#xff1f; 依賴注入&#xff08;Dependency Injection&#xff0c;DI&#xff09;是一種設計模式&#xff0c;用于減少軟件組件之間的耦合度&#xff0c;提高代碼的可測試性、…

JVM類加載機制以及雙親委派模型的介紹

目錄 1.類加載介紹 2.具體步驟 2.1加載 2.2驗證 2.3準備 2.4解析 2.5初始化 3.加載過程中的策略-雙親委派模型 1.類加載介紹 類加載,指的是Java進程在運行的時候,把.class文件從硬盤讀取到內存,并進行一系列校驗解析的過程. .class文件>類對象.硬盤>內村 類加載…

spring-boot自定義網站頭像(favicon.ico文件)

一、將ico文件存放到resources目錄的static中的favicon下。 二、在application.properties文件中增加配置 spring.mvc.favicon.enabledfalse 三、如需頁面引用如下&#xff1a; <link rel"icon" type"image/x-icon" ref"${request.contextPat…

智能駕駛規劃控制理論學習03-基于采樣的規劃方法

目錄 一、基于采樣的規劃方法概述 二、概率路圖&#xff08;PRM&#xff09; 1、核心思想 2、實現流程 3、算法描述 4、節點連接處理 5、總結 三、快速搜索隨機樹&#xff08;RRT&#xff09; 1、核心思想 2、實現流程 3、總結 4、改進RRT算法 ①快速搜索隨機圖&a…

【計算機網絡實踐】在windows上配置Xshell和Xftp連接Ubuntu系統

hebut的課下作業&#xff0c;學習使用Xshell和Xftp連接Linux系統 1. 軟件需求 Windows10/11、已安裝VM虛擬機的ubuntu系統、Xshell、Xftp。 Xshell和Xftp在家庭/學校免費 - NetSarang Website (xshell.com)里面可以下載到&#xff0c;上面需要的兩個軟件都在&#xff0c;官網免…

運籌學_1.1.2 線性規劃問題-圖解法

1.1.2 線性規劃問題-圖解法 一、圖解法求解步驟&#xff08;只適用于兩個決策變量問題&#xff09;二、圖解法作圖實例三、圖解法分析線性規劃幾種解的情況1、唯一最優解2、無窮多最優解3、無界解4、無解或無可行解 四、圖解法的幾點啟示 一、圖解法求解步驟&#xff08;只適用…

C++sort排序

前言&#xff1a; C語言的sort函數是一類用于數組排序的函數以下是其簡單的使用&#xff1a; 1.頭文件&#xff1a; #include<algorithm> 2.使用命名空間&#xff1a; using namespace std; 3.函數形式&#xff1a; sort(數組名,數組名元素個數,排序函數); 默認排…

深入淺出Redis(一):對象與數據結構

引言 Redis是一款基于鍵值對的數據結構存儲系統&#xff0c;它的特點是基于內存操作、單線程處理命令、IO多路復用模型處理網絡請求、鍵值對存儲與簡單豐富的數據結構等等 這篇文章主要圍繞Redis中的對象與數據結構來詳細說明鍵值對存儲與簡單豐富的數據結構這兩大特點 Redi…

運籌學_1.1.4 線性規劃問題-解的概念

1.1.4 線性規劃問題-解的概念 一、可行解與最優解二、基的概念三、基變量、基向量&#xff1b;非基變量、非基向量&#xff1b;基解、基可行解&#xff1b;四、最優解與可行解、基可行解的關系五、用例題&#xff08;枚舉法&#xff09;鞏固基解、基可行解、最優解三個概念1、例…

flyway實戰

flyway是一款用來管理數據庫版本的工具框架 一, 添加依賴 <dependency><groupId>org.flywaydb</groupId><artifactId>flyway-core</artifactId> </dependency> <dependency><groupId>org.springframework</groupId>&l…

第十一屆藍橋杯省賽第一場C++ A組 / B組《網絡分析》(c++)

1.題目說明 小明正在做一個網絡實驗。 他設置了 n 臺電腦&#xff0c;稱為節點&#xff0c;用于收發和存儲數據。 初始時&#xff0c;所有節點都是獨立的&#xff0c;不存在任何連接。 小明可以通過網線將兩個節點連接起來&#xff0c;連接后兩個節點就可以互相通信了。 兩…

代碼隨想錄算法訓練營第二十五天 | 216.組合總和III 17.電話號碼的字母組合

216.組合總和III https://programmercarl.com/0216.%E7%BB%84%E5%90%88%E6%80%BB%E5%92%8CIII.html#%E5%85%B6%E4%BB%96%E8%AF%AD%E8%A8%80%E7%89%88%E6%9C%AC class Solution:def combinationSum3(self, k: int, n: int) -> List[List[int]]:result [] # 存放結果集sel…

實現一個移動端焦點輪播圖

HTML結構&#xff1a; 創建一個輪播圖的容器&#xff0c;并在其中放置輪播圖片。 <div id"carousel"> <div class"carousel-item active"> <img src"image1.jpg" alt"Image 1"> </div> <div class&q…

Docker部署ZooKeeper

在分布式系統中,ZooKeeper是一個關鍵的組件,用于協調和管理多個節點之間的狀態。本文將詳細介紹如何使用Docker安裝和部署ZooKeeper,包括非集群部署和集群部署兩種情況。 非集群部署 前期準備 在開始之前,請確保你已經安裝了Docker,并且擁有sudo權限。 關閉防火墻和SEL…