数据库知识整理——SQL访问控制

数据控制控制的是用户对数据的存储权力,是由 DBA (Database Administrator,数据库管理员)决定的。但是,某个用户对某类数据具有何种权利,是个政策问题而不是技术问题。DBMSDatabase Management System,数据库管理系统) 的功能就是保证这些决定的执行。

授权

语句格式

sql 复制代码
GRANT <杈限>[,<杈限>]...[ON<对象类型><对象名>]TO <用户>[,<用户]>...
[WITH GRANT OPTION];

注意点

  • PUBLIC:接受权限的用户可以是单个或多个具体的用户,PUBLIC 参数可将权限赋给全体用户。
  • WITH GRANT OPTION:若指定了此子句,那么获得了权限的用户还可以将权限赋给其他用户。
  • 各种操作对象对应的操作权限:

例子

  • 将对供应商S、零件P、项目J的所有操作权限赋给用户 Userl 及 User2
sql 复制代码
GRANT ALL PRIVILEGES ON TABLE S,P,I TO Userl, User2;
  • 将对供应商S的插入权限赋给用户 User1,并允许将此权限赋给其他用户
sql 复制代码
GRANT INSERT ON TABLE S TO UserI WITH GRANT OPTION:
  • DBA 把数据库 SPJ 中建立表的权限赋给用户 User1
sql 复制代码
GRANT CREATETAB ON DATABASE SPJ TO Userl

收回

语句格式

sql 复制代码
REVOKE<权限>[,<权限>....[ON<对象类型><对象名>]FROM <用户>[,<用户>]...;

例子

  • 将用户 User1 及 User2 对供应商 S、零件 P、项目J的所有操作权限收回。
sql 复制代码
REVOKE ALL PRIVILEGES ON TABLE S.PIFROM Userl, User2:
  • 将所有用户对供应商S的所有查询权限收回。
sql 复制代码
REVOKE SELECT ON TABLE S FROM PUBLIC:
  • 将 User1 用户对供应商$的供应商编号 Sno 的修改权限收回。
sql 复制代码
REVOKE UPDATE(Sno) ON TABLE S FROM Userl;
相关推荐
睡不醒男孩0308233 分钟前
第七篇:揭秘 PostgreSQL 数据库内核级管控:CLup 深度架构设计与高可用底座技术白皮书
数据库·postgresql·clup
cmes_love40 分钟前
Level 2逐笔成交历史数据下载方法笔记
数据库·笔记·oracle
swordbob1 小时前
MySQL字符集陷阱:从Oracle迁移踩坑到utf8mb4强制规范
数据库·sql
牛油果子哥q1 小时前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
十五年专注C++开发1 小时前
MySql中各种功能用sql语句实现总结
数据库·sql·mysql
数据库小学妹2 小时前
AI时代数据库怎么选?多模融合、数据统一存储与选型实战指南
数据库·人工智能·经验分享·ai
Albert Edison2 小时前
【Redis】Centos7.9 安装 Redis 5 教程
数据库·redis·缓存
云计算磊哥@2 小时前
运维开发宝典026-MySQL02数据库表操作
运维·数据库·运维开发
小二·2 小时前
Redis 内存溢出(OOM)排查与恢复实战
数据库·redis·bootstrap
pqk6V6Vep2 小时前
Redis 分布式锁进阶第一篇讲解
数据库·redis·分布式