站长资讯网
最全最丰富的资讯网站

MySQL基本使用(二)之DCL语句和聚合函数

MySQL基本使用(二)之DCL语句和聚合函数

【相关学习推荐:mysql教程(视频)】

DCL

DCL 比较简单,主要用于授予或收回访问数据库的权限,以及数据库事务的提交和回滚。

授予/收回权限

以授予权限为例,我们新建一个数据库后,想要授予特定用户该数据库的访问和操作权限(一般在生产环境为了安全起见,不会通过 root 用户操作数据库),为此我们先要创建一个特定用户,比如 test,DCL 这种控制级的 SQL 语句一般在命令行执行,我们进入 MySQL Docker 容器,连接到数据库,通过 CREATE USER 语句新建一个 test 用户,同时将密码设置为 test

MySQL基本使用(二)之DCL语句和聚合函数

创建完成后,就可以在 mysql.user 数据表中看到这个用户了:

MySQL基本使用(二)之DCL语句和聚合函数

Host 字段为 % 表示 test 用户可以从任何主机连接到 MySQL 服务器。

或者通过命令行查看(这里用到了 SQL 查询语句):

MySQL基本使用(二)之DCL语句和聚合函数

然后我们就可以运行 GRANT 语句授予 test 用户对 test 数据库的所有操作权限了:

MySQL基本使用(二)之DCL语句和聚合函数

授权后,需要运行 flush privileges; 刷新权限,这样就可以在 test 数据库的权限列表中看到这个用户了:

MySQL基本使用(二)之DCL语句和聚合函数

如果我们退出当前登录状态,以 test 用户登录,就只能看到 test 数据库,因为它对其他数据库没有操作权限:

MySQL基本使用(二)之DCL语句和聚合函数

要撤回权限,需要以 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 语句回滚事务。

我们在命令行中简单演示下数据库事务的操作:

MySQL基本使用(二)之DCL语句和聚合函数

我们通过 BEGIN 语句开启事务,但是在执行多条语句后,没有通过 COMMIT 提交事务,测试执行这几条 SQL 语句,进入「浏览」面板查看,发现并没有插入新的记录:

MySQL基本使用(二)之DCL语句和聚合函数

如果在上述 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 语句,则可以顺利提交修改:

MySQL基本使用(二)之DCL语句和聚合函数

MySQL基本使用(二)之DCL语句和聚合函数

关于常见的 SQL 语句和 phpMyAdmin 中的可视化演示,就简单介绍到这里,

赞(0)
分享到: 更多 (0)
网站地图   沪ICP备18035694号-2    沪公网安备31011702889846号