|名词定义|
数据控制语言(Data Control Language, DCL)是SQL语言四大主要分类之一,是用来设置或者更改数据库用户或角色权限的语句,通过GRANT或REVOKE实现权限控制,确定单个用户和用户组对数据库对象的访问。某些RDBMS可用GRANT或REVOKE控制对表单个列的访问。在默认状态下,只有sysadmin、dbcreator、db_owner或db_securityadmin等角色的成员才有权利执行数据控制语言。
| 发展历程 |
SQL(Structure Query Language)语言是数据库的核心语言。数据控制语言DCL是SQL语言四大主要分类之一。SQL的发展是从1974年开始的,其发展过程如下:
1974年—–由Boyce和Chamberlin提出,当时称SEQUEL。
1976年—–IBM公司的Sanjase研究所在研制RDBMS SYSTEM R时改为SQL。
1979年—–ORACLE公司发表第一个基于SQL的商业化RDBMS产品。
1982年—–IBM公司出版第一个RDBMS语言SQL/DS。
1985年—–IBM公司出版第一个RDBMS语言DB2。
1986年—–美国国家标准化组织ANSI宣布SQL作为数据库工业标准。
SQL是一个标准的数据库语言,是面向集合的描述性非过程化语言。它功能强,效率高,简单易学易维护(迄今为止,我还没见过比它还好学的语言)。然而SQL语言由于以上优点,同时也出现了这样一个问题:它是非过程性语言,即大多数语句都是独立执行的,与上下文无关,而绝大部分应用都是一个完整的过程,显然用SQL完全实现这些功能是很困难的。所以大多数数据库公司为了解决此问题,作了如下两方面的工作:(1)扩充SQL,在SQL中引入过程性结构;(2)把SQL嵌入到高级语言中,以便一起完成一个完整的应用。
| 技术特点 |
数据控制语言的语句包括动词GRANT、DENY、REVOKE等,其功能如下:
GRANT:此命令用于把语句权限或者对象权限授予给其他用户和角色。语法形式是GRANT {ALL | statement[,...n]} TO security_account [ ,...n ]
DENY:此命令用于拒绝给当前数据库内的用户或者角色授予权限,并防止用户或角色通过其组或角色成员继承权限。语法形式是DENY { ALL | statement [ ,...n ] } TO security_account [ ,...n ]
REVOKE:REVOKE语句是与GRANT语句相反的语句,它能够将以前在当前数据库内的用户或者角色上授予或拒绝的权限删除,但是该语句并不影响用户或者角色从其他角色中作为成员继承过来的权限。语法形式是REVOKE { ALL | statement [ ,...n ] } FROM security_account [ ,...n ]
| 相关词 |
SQL - Structure Query Language语言是数据库的核心语言
GRANT – 授权
REVOKE – 撤销用户的访问权限
| 案例展示 |
使用基于DCL的数据库。
MySQL - 是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。
Oracle - 是是甲骨文公司的一款关系数据库管理系统。
Hive – 是基于Hadoop的一个数据仓库工具,用来进行数据提取、转化、加载。
HBase –是一个分布式的、面向列的开源数据库。
| 资料来源 |
MySQL Introduction https://www.mysql.com/MySQL Tutorials https://www.w3schools.in/mysql/ddl-dml-dcl/SQL Introduction https://www.w3schools.com/sql/sql_intro.asp
杨波,许丽娟主编;陈刚,骆珍仪,李思思副主编.电子商务概论:北京邮电大学出版社,2014.08
Data Control Language (DCL) for Database Permissions https://www.lifewire.com/data-control-language-dcl-1019477
SQL Data Control Language (DCL) https://www.tutorialride.com/dbms/sql-data-control-language-dcl.htm
Explain Data Control Language (DCL) with Examples in DBMS https://whatisdbms.com/explain-data-control-language-dcl-with-examples-in-dbms/