Oracle 用戶權限與對象權限詳解

一、權限體系概述

Oracle 數據庫的權限管理是保障數據安全的核心機制,主要分為系統權限(System Privileges)?和對象權限(Object Privileges)?兩大類:

  • 系統權限:賦予用戶在數據庫中執行特定操作的能力(如創建表、刪除用戶等)
  • 對象權限:賦予用戶對特定數據庫對象(如表、視圖、存儲過程等)的操作權限
二、系統權限(System Privileges)
1. 核心系統權限分類
權限類別常見系統權限示例說明
會話權限CREATE SESSION允許用戶連接數據庫
模式對象權限CREATE TABLEALTER TABLEDROP TABLE管理表、視圖等模式對象的權限
空間管理權限UNLIMITED TABLESPACE允許使用表空間的無限配額
角色與權限管理GRANT ANY PRIVILEGECREATE ROLE授予其他用戶權限或創建角色
系統管理權限ALTER DATABASESHUTDOWN DATABASE數據庫級別的管理操作(通常僅 DBA 擁有)
2. 系統權限的授予與回收
  • 授予語法
    GRANT <系統權限> TO <用戶/角色/PUBLIC> [WITH ADMIN OPTION];
    
    ?
    • WITH ADMIN OPTION:允許接收者將權限再授予其他用戶
  • 回收語法
    REVOKE <系統權限> FROM <用戶/角色/PUBLIC>;
    
3. 特殊系統權限角色
  • DBA 角色:包含幾乎所有系統權限,用于數據庫管理員(如GRANT DBA TO admin_user;
  • RESOURCE 角色:包含創建表、序列、存儲過程等開發相關權限
  • CONNECT 角色:基本會話權限及簡單對象操作權限(Oracle 12c 后逐漸棄用)
三、對象權限(Object Privileges)
1. 支持對象權限的對象類型
對象類型支持的對象權限
表 / 視圖SELECTINSERTUPDATEDELETEALTERINDEXREFERENCESTRIGGER
序列SELECTUPDATE
存儲過程EXECUTE
同義詞依賴原對象權限(通過同義詞訪問時需原對象權限)
2. 對象權限的具體說明
  • SELECT:查詢表 / 視圖數據
  • INSERT:向表 / 視圖插入數據
  • UPDATE:更新表 / 視圖數據(可指定列級權限,如UPDATE(col1, col2)
  • DELETE:刪除表 / 視圖數據
  • REFERENCES:創建外鍵約束時引用表
  • EXECUTE:調用存儲過程、函數或包
3. 對象權限的授予與回收
  • 授予語法
    GRANT <對象權限> ON <對象名> TO <用戶/角色/PUBLIC> [WITH GRANT OPTION];
    
    ?
    • WITH GRANT OPTION:允許接收者將對象權限再授予其他用戶
  • 列級權限示例
    GRANT UPDATE(name, salary) ON employees TO hr_clerk;
    
  • 回收語法
    REVOKE <對象權限> ON <對象名> FROM <用戶/角色/PUBLIC>;
    
四、權限管理高級特性
1. 角色(Roles)的使用
  • 作用:批量管理權限的容器,可將多個權限放入角色后統一授予用戶
  • 創建與授權
    CREATE ROLE developer_role;
    GRANT CREATE TABLE, CREATE PROCEDURE TO developer_role;
    GRANT developer_role TO app_developer;
    
2. PUBLIC 角色
  • 特性:默認包含所有用戶,可向 PUBLIC 授予公共權限
  • 風險提示:如GRANT SELECT ON system_table TO PUBLIC可能導致數據泄露
3. 權限查詢與監控
  • 查詢用戶擁有的系統權限
    SELECT * FROM user_sys_privs;  -- 當前用戶權限
    SELECT * FROM dba_sys_privs WHERE grantee = 'USER_NAME';  -- 指定用戶權限
    
  • 查詢用戶擁有的對象權限
    SELECT * FROM user_tab_privs;  -- 當前用戶對象權限
    SELECT * FROM dba_tab_privs WHERE grantee = 'USER_NAME';  -- 指定用戶對象權限
    
五、權限管理最佳實踐
  1. 最小權限原則:僅授予用戶完成任務所需的最低權限
  2. 角色分層管理:按業務場景創建角色(如開發角色、查詢角色、管理員角色)
  3. 定期權限審計:通過AUDIT語句監控權限使用,或查詢審計日志
  4. 避免直接授權給 PUBLIC:減少公共權限帶來的安全隱患
  5. 列級權限控制:對敏感數據(如薪資、密碼)使用列級權限限制
六、示例場景
場景 1:創建開發用戶并授予基礎權限
-- 創建用戶
CREATE USER dev_user IDENTIFIED BY dev123;
-- 授予會話權限和開發權限
GRANT CREATE SESSION, RESOURCE TO dev_user;
-- 授予特定表查詢權限
GRANT SELECT ON sales_data TO dev_user;

場景 2:通過角色管理團隊權限
-- 創建數據分析角色
CREATE ROLE data_analyst_role;
-- 授予查詢和分析權限
GRANT SELECT, CREATE VIEW ON data_schema.* TO data_analyst_role;
-- 授予團隊成員角色
GRANT data_analyst_role TO analyst1, analyst2, analyst3;

通過合理管理系統權限與對象權限,可在保障數據庫安全的同時,滿足不同用戶的業務需求。建議結合企業安全策略,定期優化權限分配,避免權限濫用風險。

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

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

相關文章

kubectl get pods 時 “client-side throttling, not priority and fairness“ 原因初探

1. 問題起源 在kubernetes里&#xff0c;使用kubectl get pods 時&#xff0c;返回 I0508 05:43:04.655602 100742 request.go:668] Waited for 1.178494016s due to client-side throttling, not priority and fairness, request: GET:https://10.103.0.1:443/apis/cert-ma…

力扣網C語言編程題:位運算來解決 “尋找重復數”

一. 簡介 前面兩篇文章解決力扣網上"查找重復數"的題目&#xff0c;提供了三種思路&#xff1a;哈希表、二分法和快慢指針。文章如下&#xff1a; 力扣網C語言編程題&#xff1a;“尋找重復數”的兩種思路-CSDN博客 力扣網C語言編程題&#xff1a;快慢指針來解決 …

3D視覺感知

目錄 3D視覺感知任務 單目3D感知 單目3D物體檢測 – 直接預測3D信息 單目3D物體檢測 – 總結 單目深度估計 雙目3D感知 多目3D感知 3D視覺感知任務 ? 輸入&#xff1a;單攝像頭或多攝像頭生成的圖像數據 ? 單張圖像 ? 圖像序列 ? 輸出 ? 稀疏&#xff1a…

es中常規的根據字段查詢時走什么索引(說明:「常規的根據字段查詢」不包含分詞查詢)

在Elasticsearch中&#xff0c;“常規的根據字段查詢”且不涉及分詞的查詢&#xff08;如精確匹配、范圍查詢&#xff09;&#xff0c;主要依賴以下索引機制&#xff1a; 一、核心索引類型及適用場景 字段類型索引結構典型查詢方式應用場景keyword倒排索引&#xff08;未分詞…

MYSQL如何插入數據,效率會更高

在MySQL中&#xff0c;插入數據的效率可以通過多種方式逐步提升。以下是從簡單到復雜的優化路徑&#xff0c;幫助你逐步提高數據插入的性能&#xff1a; 一、基礎插入&#xff1a;逐條插入 這是最基礎的插入方式&#xff0c;適用于少量數據的插入操作。雖然簡單&#xff0c;但…

Rabbitmq的五種消息類型介紹,以及集成springboot的使用

交換機類型 Fanout Exchange 扇型交換機&#xff0c;這個交換機沒有路由鍵概念&#xff0c;就算你綁了路由鍵也是無視的。 這個交換機在接收到消息后&#xff0c;會直接轉發到綁定到它上面的所有隊列 Direct Exchange 直連型交換機&#xff0c;根據消息攜帶的路由鍵將消息投遞…

日語學習-日語知識點小記-進階-JLPT-真題訓練-N2階段(4):2022年12月2023年12月

日語學習-日語知識點小記-進階-JLPT-真題訓練-N2階段&#xff08;4&#xff09;&#xff1a;2022年12月&2023年12月 1、前言&#xff08;1&#xff09;情況說明&#xff08;2&#xff09;工程師的信仰&#xff08;3&#xff09;真題訓練 2、2個卷的單詞部分1、 真題-2023年…

從代碼學習深度強化學習 - Actor-Critic 算法 PyTorch版

文章目錄 前言算法原理1. 從策略梯度到Actor-Critic2. Actor 和 Critic 的角色3. Critic 的學習方式:時序差分 (TD)4. Actor 的學習方式:策略梯度5. 算法流程代碼實現1. 環境與工具函數2. 構建Actor-Critic智能體3. 組織訓練流程4. 主程序:啟動訓練5. 實驗結果總結前言 在深…

Python 數據分析與可視化 Day 8 - Pandas 高級操作技巧

? 今日目標 掌握 Pandas 的索引體系&#xff08;Index / MultiIndex&#xff09;使用 set_index() 和 reset_index() 管理數據索引理解 pivot_table 與 melt、stack/unstack 重塑數據形態初步理解“寬表”與“長表”在數據分析與可視化中的應用場景 &#x1f4da; 一、深入理…

Spring Boot整合百度AI人臉比對實戰

目錄 一、簡述 二、依賴 三、代碼步驟 3.1 實體注入 3.2 服務實現 3.3 其它實現 四、小結 歡迎來到 盹貓(>^ω^<)的博客 本篇文章主要介紹了 [Spring Boot整合百度AI人臉比對實戰] ?博主廣交技術好友&#xff0c;喜歡文章的可以關注一下? 一、簡述 人臉識別在日…

使用 pip 安裝 numpy 包卡在 Preparing metadata 階段問題解決

TOC 1 問題描述 使用 pip 安裝numpy卡在下面最后一行的階段&#xff1a; Collecting numpy1.26.4 (from -r requirements.txt (line 2))Using cached https://mirrors.aliyun.com/pypi/packages/65/6e/09db70a523a96d25e115e71cc56a6f9031e7b8cd166c1ac8438307c14058/numpy-…

新手向:Anaconda3的安裝與使用方法

我們在剛開始接觸Python時使用的是Python的直接編譯器,如果我們需要進行其他的項目編寫往往需要使用另一個版本的Python ,這樣反復的下載很是麻煩并且還會造成系統變量的紊亂.這次我們引入Anaconda3,可創建虛擬的Python環境,滿足不同項目的需要,當不用的時候可以直接放心刪除不…

C#中的設計時構造函數

以下是關于設計時構造函數的詳細整理&#xff0c;包括定義、適用場景、相關概念和實際應用&#xff1a; 一、設計時構造函數的定義 設計時構造函數&#xff08;Design-time Constructor&#xff09;是專門為開發工具&#xff08;如Visual Studio、Blazor Designer等&#xff0…

Spring Boot 2.x 項目搭建 (一)

以下是基于Spring Boot 2.x&#xff08;兼容JDK 1.8&#xff09;的項目搭建指南及Markdown文檔生成方案&#xff0c;整合了多個搜索結果中的最佳實踐&#xff1a; 一、項目初始化 1. 使用Spring Initializr創建項目 步驟&#xff1a; 訪問 start.spring.io 或通過IDE&#x…

Kotlin作用域函數:掌握apply/let/run/with/also精髓

一、作用域函數詳解 1. apply&#xff1a;對調用對象進行配置或操作&#xff0c;并返回該對象本身。 接收者引用&#xff1a;this&#xff08;可省略&#xff0c;直接調用接收者成員&#xff09;返回值&#xff1a;接收者對象本身&#xff08;T&#xff09;核心用途&#xff…

Spring Boot監視器:應用監控終極指南

Spring Boot 監視器詳解 Spring Boot 監視器(Monitor)是用于監控和管理 Spring Boot 應用程序運行狀態的核心組件,主要通過 Spring Boot Actuator 和 Spring Boot Admin 兩大工具實現。 一、核心監視器組件 1. Spring Boot Actuator 功能定位:提供應用程序內部運行狀態的原…

SpringBoot 中 @Transactional 的使用

SpringBoot 中 Transactional 的使用 一、Transactional 的基本使用二、Transactional 的核心屬性三、使用避坑&#xff08;失效場景&#xff09;3.1 自調用問題3.2 異常處理不當3.3 類未被 Spring 管理3.4 異步方法內使用失效 四、工作實踐4.1 事務提交之后執行一些操作4.2 事…

6.26_JAVA_微服務_Elasticsearch

1、ES文檔中keyword意思是&#xff1a;字符串&#xff0c;但不需要分詞 2、ES細節CreateIndexRequest request new CreateIndexRequest("items");會讓你導包&#xff0c;會有兩個選擇&#xff1a; import org.elasticsearch.action.admin.indices.create.CreateInd…

Java 大視界 -- 基于 Java 的大數據可視化在智慧城市能源消耗動態監測與優化決策中的應用(324)

Java 大視界 -- 基于 Java 的大數據可視化在智慧城市能源消耗動態監測與優化決策中的應用&#xff08;324&#xff09; 引言&#xff1a;正文&#xff1a;一、Java 驅動的能源數據采集與預處理基建1.1 多源異構數據合規接入層&#xff08;ISO 50001IEC 61850 雙標準適配&#x…

C++ 快速回顧(二)

C 快速回顧&#xff08;二&#xff09; 前言一、友元類二、友元函數三、深淺拷貝淺拷貝深拷貝 前言 用于快速回顧之前遺漏或者補充C知識 一、友元類 友元的優點是可以快速的輕松的訪問的原本由于私有保護的字段和函數&#xff0c;同時這也是它的缺點這樣破壞了原本封裝性。 …