SQL 语言:数据控制

文章目录

    • 概述
    • 授权(GRANT)
    • 销权(REVOKE)
    • 总结

概述

SQL语言中的数据控制权限分配是数据库管理的重要组成部分,它涉及到如何合理地为用户分配对数据库资源的访问和使用权限。

  1. 权限类型:在SQL中,权限主要分为两类,即系统权限和对象权限。系统权限允许用户执行特定的数据库操作,如创建或删除数据库、修改数据库结构等。对象权限则更具体,它涉及到对特定数据库对象的操作,如对表、视图、存储过程等的SELECT、INSERT、UPDATE、DELETE权限。
  2. 权限分配:权限可以通过GRANT语句分配给用户或角色。通过将权限授予角色,然后再将角色分配给用户,可以简化权限管理。权限的分配可以是多层次的,即超级用户可以将权限授予其他用户,而那些用户也可以将他们的一部分或全部权限授予其他用户。
  3. 权限回收:使用REVOKE语句可以删除以前授予的权限。这可以用于限制用户的访问,或者在员工离职时确保他们不再有权限访问数据库。
  4. 权限的级联:在某些数据库系统中,权限的分配和回收可以设置为级联。这意味着当一个用户被授予权限,这些权限也会自动授予该用户创建的所有对象。同样,当从一个用户撤销权限时,该用户的所有对象也将失去相应的权限。
  5. 权限和安全性:权限分配不仅关系到数据库的正常使用,也直接影响到数据库的安全性。合理的权限分配可以防止未授权访问和数据泄露,是保护数据不被恶意攻击的重要手段。
  6. 权限和数据完整性:适当的权限分配有助于维护数据完整性。通过限制对数据的写入和修改权限,可以确保只有具备相应权限的用户才能修改数据,从而减少数据损坏的风险。
  7. 权限和审计:权限分配还与审计有关。数据库管理员可以通过审查权限分配情况来监控和评估数据库的安全状况。
  8. 权限管理的实际操作:在实际操作中,数据库管理员需要定期审查和更新权限分配,以适应不断变化的业务需求和安全环境。这可能包括添加新用户、删除旧用户、调整权限级别等。

本文要讲的数据控制是控制用户对数据的操作和存储权力,是由 DBA 来决定的。DBMS 数据控制应具有如下功能:

(1)通过 GRANT 和 REVOKE 将授权通知系统,并存入数据字典。

(2)当用户提出请求时,根据授权情况检查是否执行操作请求。

SQL标准包括 DELETE、INSERT、SELECT 和 UPDATE 权限。SELECT 权限对应于 READ 权限,SQL 还包括了 REFERENCES 权限,用来限制用户在创建关系时定义外码的能力。

授权(GRANT)

授权语法格式:

GRANT <权限>[,<权限>]...
[ON<对象类型><对象名>]
TO <用户>[,<用户>]...
[WITH GRANT OPTION]

注意:若指定了 WITH GRANT OPTION 子句,那么获得了权限的用户还可以将权限赋给其他用户;接受权限的用户可以是单个或多个具体的用户,PUBLIC 参数可将权限赋给全体用户。不同类型的操作对象有不同的操作权限,常见的操作权限如下所示:

image

示例1. 如果用户要求把数据库SPJ中供应商S、零件P、项目J表赋予各种权限。各种授权要求如下:

(1) 将对供应商S、零件P、项目J的所有操作权限赋给用户 USER1 及 USER2。

(2) 将对供应商S的插入权限赋给用户 USER1,并允许将此权限赋给其他用户。

(3) DBA 把数据库 SPJ 中建立表的权限赋给用户 USER1。

参考答案:

(1)GRANT ALL PRIVILEGES ON TABLE S,P,J TO USER1,USER2;

(2)GRANT INSERT ON TABLE S TO USER1 WITH GRANT OPTION;

(3)GRANT CREATE TABLE ON DATABASE SPJ TO USER1;

销权(REVOKE)

销权语法格式:

REVOKE <权限>[,<权限>]...
[ON<对象类型><对象名>]
FROM <用户>[,<用户>]...
[RESTRICT|CASCADE];

其中:RESTRICT 表示只收回指定用户的权限,默认;CASCADE 表示收回指定用户及其授予的其他用户的该权限。

示例2. 要求回收用户对数据库SPJ中供应商S、零件P、 项目J表的操作权限。各种收回权限的要求如下:

(1) 将用户USER1 及USER2对供应商S、零件P、项目J的所有操作权限收回。

(2) 将所有用户对供应商S的所有查询权限收回 。

(3)将USER1 用户对供应商S的供应商编号Sno的修改权限收回。

参考答案:

(1) REVOKE AL PRIVILEGES ON TABLE S,P,J FROM USER1, USER2;

(2) REVOKE SELECT ON TABLE S FROM PUBLIC;

(3) REVOKE UPDATE(Sno) ON TABLE S FROM USER1;

示例3. 收回用户LI对表EMPLOYEE的查询权限,同时级联收回LI授予其他用户的该权限,SQL语句为: (1) SELECT ON TABLE EMPLOYEE FROM LI (2) ;

(1) A.GRANT    B.GIVE    C.CALL BACK    D. REVOKE

(2) A.RESTRICT    B.CASCADE    C.WITH GRANT OPTION    D. WITH CHECK OPTION

答案:(1)的正确选项为D,(2)的正确选项为B。

总结

总之,SQL语言提供了一套全面的数据控制机制,包括数据安全性、完整性、并发和恢复控制,使得数据库管理员能够有效地管理和维护数据库系统。通过合理地设置和使用这些控制机制,可以确保数据库的稳定性、可靠性和安全性,从而为应用程序和最终用户提供一致和可信的数据服务。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/655459.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【C++】list的使用方法和模拟实现

❤️欢迎来到我的博客❤️ 前言 list是可以在常数范围内在任意位置进行插入和删除的序列式容器&#xff0c;并且该容器可以前后双向迭代list的底层是双向链表结构&#xff0c;双向链表中每个元素存储在互不相关的独立节点中&#xff0c;在节点中通过指针指向其前一个元素和后…

双击移动硬盘打不开?原因分析与数据恢复全攻略

在日常生活和工作中&#xff0c;移动硬盘作为数据存储和传输的重要工具&#xff0c;扮演着至关重要的角色。然而&#xff0c;当我们遇到双击移动硬盘无法打开的情况时&#xff0c;往往会感到十分困扰。本文将详细探讨双击移动硬盘打不开的原因&#xff0c;并提供两种有效的数据…

混合A*算法详解(二)路径平滑

描述 上一篇文章混合A*算法详解&#xff08;一&#xff09;路径搜索 路径损失函数使用Voroni势能图 根据之前的文章分析&#xff0c;决定A*路径长度的有两点&#xff1a;路径长度和距离障碍物远近。Voroni图用于权衡这两者。之前我在记录二维点云的阿尔法形状算法时简单介绍过…

AAA实验配置

一、实验目的 掌握AAA本地认证的配置方法 掌握AAA本地授权的配置方法 掌握AAA维护的方法 1.搭建实验拓扑图 2.完成基础配置&#xff1a; 3.使用ping命令测试两台设备的连通性&#xff1a; 二、配置AAA 1.打开R1&#xff1a;配置AAA方案 这两个方框内的可以改名&#xff0c…

linux安装Java报错cannot execute binary file: Exec format error

uname -a 查看自己jdk版本 下载JDK路径Java Archive Downloads - Java SE 17 下载对应的版本jdk jdk-17.0.10_linux-aarch64_bin.tar.gz jdk-17.0.10_linux-x64_bin.tar.gz

【C#】委托

文章目录 委托自定义委托模板方法&#xff08;工厂模式回调(callback)函数&#xff08;观察者模式多播&#xff08;multicast&#xff09;委托委托的高级使用使用接口 重构 模板方法代码注意参考 委托 委托&#xff08;delegate&#xff09;是一种类型&#xff0c;定义了一种方…

为什么会有websocket(由来)

一、HTTP 协议的缺点和解决方案 1、HTTP 协议的缺点和解决方案 用户在使用淘宝、京东这样的网站的时候&#xff0c;每当点击一个按钮其实就是发送一个http请求。那我们先来回顾一下http请求的请求方式。 一个完整的http请求是被分为request请求节点和response响应阶段的&…

element ui 下拉框Select 选择器 上下箭头旋转方向样式错乱——>优化方案

目录 前言1、问题复现2、预期效果3、input框样式修改解析4、修改方案 &#x1f680;写在最后 前言 测试A&#xff1a;那啥&#xff01;抠图仔&#xff0c;样式怎么点着点着就出问题了。 前端&#xff1a;啥&#xff1f;css样式错乱了&#xff1f;你是不是有缓存啊&#xff01…

淘宝扭蛋机小程序:探索未知,扭出惊喜

在数字时代&#xff0c;我们一直在寻找一种新颖、有趣且充满惊喜的购物方式。淘宝扭蛋机小程序正是为了满足这一需求而诞生的创新之作&#xff0c;它将传统扭蛋机的乐趣与淘宝的丰富商品库完美结合&#xff0c;为您带来前所未有的购物体验。 打破传统&#xff0c;创新玩法 淘…

编程零基础,如何学习Python?

初学者选择Python入手着实是一个不错的方向&#xff0c;入手简单且广泛的运用是它最显著的特色了。 那有几个问题&#xff0c;我想是开始学习Python之前应该了解的&#xff0c; python能做什么&#xff1f; 发展前景与工作机会有哪些&#xff1f; 需要学习哪些内容&#xf…

Windows 使用技巧

Windows 使用技巧 ①局域网内共享文件 ②CTRL Y 和 CTRL Z ①局域网内共享文件 第一步&#xff1a; 选择要共享的文件&#xff08;分享方操作&#xff09; 第二步&#xff1a; 右键打开属性&#xff0c;选择共享&#xff08;分享方操作&#xff09; 第三步&#xff1a; …

Python在忘mysql密码后该如何重新连mysql

步骤一 先到mysql的bin目录下 步骤二 用mysqld delete mysql 把之前的库删了 步骤三 通过管理员模式进去后 用命令mysqld --skip-grant-tables越过验证 再输入mysql -u root 直达账户 步骤四 用FLUSH PRIVILEGES; ALTER USER rootlocalhost IDENTIFIED BY new_password; 指…

JavaScript的当前时间设置及Date的运算

作者:私语茶馆 1.场景描述 如下图,在HTML刚加载时,需要将开始时间设置为默认当前时间,结束时间设置为当前时间后7天的时间。手工填写时间时,时间段不超过30天。 这里涉及到两个技术点: 1)Input Date的当前时间设置 2)date的运算 由于是动态修改HTML,所以采用…

go defer

type _defer struct {siz int32started boolopenDefer boolsp uintptrpc uintptrfn *funcval_panic *_paniclink *_defer }runtime._defer 结构体是延迟调用链表上的一个元素&#xff0c;所有的结构体都会通过 link 字段串联成链表。 只…

【电源专题】功率电感啸叫对策及案例

在文章:【电源专题】功率电感器啸叫原因及典型案例 中我们了解到了电感器啸叫的原因和一些典型电路中产生电感啸叫的案例。通过案例我们了解到很多时候啸叫来源是DC-DC转换器的功率电感器,所以如果我们要降低或消除啸叫,那有哪些对策呢? 避免流过人耳可听频率电流 首先我们…

左偏树,可合并堆

合并两个堆并维护最小或最大性质解决树上节点问题&#xff0c;从叶节点往根维护&#xff0c;每个节点看作一个堆表示到最近的叶节点的距离&#xff0c;所以每次对合并&#xff08;树高矮&#xff09;表示堆的顶点对应下标关键代码 static void dfs(int x){for(int ihead[x];i&g…

14、类与对象(采用图解方式分析内存结构)①

在idea中创建一个新文件&#xff0c;名称为Hello.java 其中&#xff0c;Hello就是一个类&#xff0c;main是这个类里面的方法&#xff0c;这意味着我们在学习的时候已经在使用类了。 对象和类 一、概念二、⭐内存分配机制分析Ⅰ、基本内存结构⭐⭐Ⅱ、调用类方法的内存分析&am…

【效率提升】Edge浏览器

现如今&#xff0c;无论是办公、学习&#xff0c;还是日常搜索、娱乐等&#xff0c;选择一个搜索快&#xff0c;准确率高&#xff0c;不卡顿&#xff0c;没广告的浏览器都是非常重要的。我想向大家推荐一款极具实力的浏览器&#xff1a;Microsoft Edge。 Microsoft Edge 浏览器…

具有固定宽度的盒子:\makebox, \parbox

makebox \makebox 是 LaTeX 中的一个命令&#xff0c;用于创建一个具有固定宽度的盒子&#xff0c;并在该盒子内放置内容。这个命令可以用于控制文本或对象的位置和对齐。 语法如下&#xff1a; \makebox[<width>][<alignment>]{<content>}其中&#xff1…

【c++leetcode】69. Sqrt(x)

问题入口 二分搜索 最困难的是能否意识到用二分搜索法解题。 算术平方根的区间在[1, x] 。代码如下&#xff1a; class Solution { public:int mySqrt(int x) {if (x 1 || x 0){return x;}int64_t start 1;int64_t end x;while (start < x){int64_t mid start (en…