【相关学习推荐:mysql教程(视频)】
DCL
DCL 比较简单,主要用于授予或收回访问数据库的权限,以及数据库事务的提交和回滚。
授予/收回权限
以授予权限为例,我们新建一个数据库后,想要授予特定用户该数据库的访问和操作权限(一般在生产环境为了安全起见,不会通过 root 用户操作数据库),为此我们先要创建一个特定用户,比如 test
,DCL 这种控制级的 SQL 语句一般在命令行执行,我们进入 MySQL Docker 容器,连接到数据库,通过 CREATE USER
语句新建一个 test
用户,同时将密码设置为 test
:
创建完成后,就可以在 mysql.user
数据表中看到这个用户了:
Host
字段为 %
表示 test
用户可以从任何主机连接到 MySQL 服务器。
或者通过命令行查看(这里用到了 SQL 查询语句):
然后我们就可以运行 GRANT
语句授予 test
用户对 test
数据库的所有操作权限了:
授权后,需要运行 flush privileges;
刷新权限,这样就可以在 test
数据库的权限列表中看到这个用户了:
如果我们退出当前登录状态,以 test
用户登录,就只能看到 test
数据库,因为它对其他数据库没有操作权限:
要撤回权限,需要以 root 身份进行,在权限列表删除这个用户,或者在命令行通过 REVOKE
语句完成:
revoke all privideges on test.* from 'test'@'%'; flush privileges;
这里操作的都是所有权限,也可以指定特定的权限:
// 授予权限 grant select on test.* to 'user1'@'localhost'; /*给予查询权限*/ grant insert on test.* to 'user1'@'localhost'; /*添加插入权限*/ grant delete on test.* to 'user1'@'localhost'; /*添加删除权限*/ grant update on test.* to 'user1'@'localhost'; /*添加权限*/ // 收回权限 revoke select on test.* from 'jack'@'localhost'; revoke insert on test.* from 'jack'@'localhost'; revoke delete on test.* from 'jack'@'localhost'; revoke update on test.* from 'jack'@'localhost';
事务提交/回滚
数据库事务(Database Transaction)是指作为单个逻辑工作单元执行的一系列操作(对数据库的相关增删改查的操作,包含一条或多条 SQL 语句),要么完全地执行,要么完全地不执行。
对于单条 SQL 语句,数据库系统自动将其作为一个事务执行,这种事务被称为隐式事务。
要手动把多条 SQL 语句作为一个事务执行,可以使用 BEGIN
开启一个事务,使用 COMMIT
提交一个事务,这种事务被称为显式事务,如果事务执行过程中出现错误或异常,可以通过 ROLLBACK
语句回滚事务。
我们在命令行中简单演示下数据库事务的操作:
我们通过 BEGIN
语句开启事务,但是在执行多条语句后,没有通过 COMMIT
提交事务,测试执行这几条 SQL 语句,进入「浏览」面板查看,发现并没有插入新的记录:
如果在上述 SQL 序列后加上 ROLLBACK
回滚事务,效果也是一样的:
BEGIN; INSERT INTO post (`title`, `content, `created_at`) VALUES ('这是一篇测试文章2', '测试内容哈哈哈', '2020-05-26 13:00:00'); INSERT INTO post (`title`, `content, `created_at`) VALUES ('这是一篇测试文章3', '测试内容哈哈哈', '2020-05-26 13:30:00'); ROLLBACK;
而如果在最后加上 COMMIT
语句,则可以顺利提交修改:
关于常见的 SQL 语句和 phpMyAdmin 中的可视化演示,就简单介绍到这里,