資料庫系統概論—安全、完整性

来源:https://www.cnblogs.com/wht-de-bk/archive/2023/05/07/17379724.html
-Advertisement-
Play Games

資料庫系統概論—基礎篇(3) 三.資料庫安全性 1.資料庫安全性概述 資料庫的安全性指保護資料庫以防不合法使用所造成的數據泄露、更改或破壞 2.資料庫安全性控制 2.1用戶身份鑒別 靜態口令鑒別 動態口令鑒別 生物鑒別特征 智能卡鑒別 2.2存取控制 自主存取控制:給用戶限權(DAC,C1級) 強制 ...


資料庫系統概論—基礎篇(3)

三.資料庫安全性

1.資料庫安全性概述

資料庫的安全性指保護資料庫以防不合法使用所造成的數據泄露、更改或破壞

2.資料庫安全性控制

2.1用戶身份鑒別

  • 靜態口令鑒別
  • 動態口令鑒別
  • 生物鑒別特征
  • 智能卡鑒別

2.2存取控制

  • 自主存取控制:給用戶限權(DAC,C1級)
  • 強制存取控制:給資料庫對象一定的密級(MAC,B1級)

2.3自主存取控制方法(授權:授予與收回)

  • 授權
Grant 許可權
on (類型,表/視圖...) 對象名1,(類型,表/視圖...) 對象名2...
to 用戶1,用戶2...
with grant option;(是否可以傳播該許可權)
  • 收回
Revoke 許可權
on (類型,表/視圖...) 對象名1,(類型,表/視圖...) 對象名2...
from 用戶1,用戶2...
CASADE/RESTRICT;(是否級聯)
  • 創建用戶
CREATE USER 用戶名 
with DBA/RESOURCE/CONNECT;

DBA:超級用戶,有所有資料庫對象的限權

RESOURCE:能創建表和視圖

CONNECT:只能在限權內操作

2.4資料庫角色

資料庫角色是一組資料庫操作相關的許可權的集合(許可權的集合)

#授予
Grant 許可權
on (類型,表/視圖...) 對象名
to 角色1,角色2...;
#收回
Grant 許可權
on (類型,表/視圖...) 對象名
to 用戶1,用戶2...;

2.5強制存取控制方法(數據加密)

主體:用戶;客體:數據

  • 主體的許可證 >= 客體的密級時,該主體才能讀取相應的客體
  • 主體的許可證 <= 客體的密級時,該主體才能相應的客體

3.視圖機制

視圖可以隱藏部分數據,控制要查詢的數據是否對用戶是可見的

4.審計

審計功能把用戶對資料庫的所有操作記錄下來放入審計日誌

四.資料庫完整性

資料庫完整性是資料庫的正確性和相容性,是為例防止資料庫中存在不符合語義的數據。

1.實體、參照完整性

  • 實體:非空唯一,在CREATE TABLE中使用PRIMART KEY定義。(主碼)
  • 參照:外碼,參照表的主碼是被參照表的主碼

2用戶自定義完整性

針對某一具體應用的數據必須滿足的語義要求。

  • 屬性上的約束(列級)

NOT BULL:列值非空

UNIQUE:列值唯一

CHECK:是否滿足條件(類型 屬性 CHECK(Ssex in('男','女'))性別在男女中選)

  • 元組上的約束(表級)

eg:當性別是男,名字不以”Ms.“開頭

建表...
CHECK(Sex = '女' or Sname not like'Ms.%');

3.完整性約束字句

給約束起名字,CONSTRAINT 約束名一起使用

CONSTRAINT 約束名 約束條件;

4.斷言

更一般的約束

#創建
CREATE ASSERTION 斷言名
CHECK字句;

#刪除
DROP ASSERTION 斷言名;

5.觸發器

由事件觸發的特殊過程(事件條件功能)

#創建
CREATE TRIGGER 觸發器名
BEFORE/ALTER 觸發事件 on 表名
REFRTENCING NEW/OLD ROW AS 變數#NEW/OLD ROW是兩個表(新/舊)
FOR EACH ROW/STATEMENT#行級/列級
WHEN 觸發事件 觸發動作;

#刪除
DROP TRIGGER 觸發器名 on 表名;

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

-Advertisement-
Play Games
更多相關文章
  • 概述 預處理器指令 指導編譯器在實際編譯之前對信息進行預處理。 所有預處理指令以#開始。並由於預處理器指令不是語句,所以沒有分號作為結尾。 一個預處理器指令,一定是這一行的唯一指令。 預處理指令列表 |預處理器指令|描述| | | | |#define|將其後的一系列 成為符號| |undef|取消 ...
  • 最近有群友問,.NET有哪些微服務框架?.NET的微服務框架還真不多,一般企業都會自己搭建微服務框架,或者基於其它框架搭建微服務(比如abp)。本文將介紹幾種微服務框架,供大家學習參考。 一、Service Fabric 簡介: Service Fabric 是一個微服務框架,它由微軟開發並托管在 ...
  • 在Winform的分頁控制項裡面,我們提供了很多豐富的功能,如常規分頁,中文轉義、導出Excel、導出PDF等,基於DevExpress的樣式的分頁控制項,我們在其上面做了不少封裝,以便更好的使用,其中就包括集成保存用戶列表顯示欄位及寬度調整設置。本篇隨筆介紹這個實現的過程,通過在當前程式中序列化方式存... ...
  • 哈嘍大家好,我是鹹魚 不知道小伙伴們在寫 Bash 腳本或者說看別人的 Bash 腳本的時候有沒有註意過腳本的第一行 #!/bin/bash Bash 腳本的第一行往往以 #! 開頭,這一行稱作 shebang 行 在 類 UNIX 系統中,shebang 行用來指定腳本的解釋器路徑,通常出現在第一 ...
  • 1.什麼是信號: 信號的種類很多,不同的控制項觸發不同的特定信號 例如button的信號:(在父類中可以找到)信號與槽同時是通過關聯使用的。 2.什麼是槽? 槽:用於關聯某一個控制項的信號,信號觸發的時候將會執行槽函數(槽函數的關聯分為手動關聯和自動關聯) 槽的自動關聯; 在前面板選中對應的控制項 右擊- ...
  • (Linux用戶相關命令) 前言 上一篇中已經預告,我們這篇主要說一說Linux中用戶相關的命令。 可能各位小伙伴用的Windows會比較多一點,在Windows操作系統中,我們知道有Administrator用戶,Administrator 是Windows系統中的管理員用戶,有著最高的許可權。 用 ...
  • 1. 還原論 1.1. 認為可以把高級現象還原為低級基本現象的學說 1.2. 將複雜的東西看成是由簡單單元組合而成的 1.2.1. 以賦值、條件分支、迴圈等作為基本處理單元,並將系統整體分割成很多這樣的單元的思維方式 1.2.2. 文件系統也是將大量的數據分割成記錄這樣的小單元進行處理的 2. 整體 ...
  • 前言 早就聽聞大名鼎鼎的GeoTools,因為自己不搞Java,所以之前沒用過, 背景 最近有個需求,一個白模系統,具體是數據是用SDE導入到postgresql中,然後用arcgis server發佈了矢量,最後用 arcgis api for js 4.x拉伸,得到有高度的白模。以前的數據都是通 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...