MySQL权限篇之CREATE

这篇博客详细介绍了MySQL中的CREATE权限,包括用户如何创建数据库、表和隐式索引。通过示例展示了不同授权方式的区别,如仅限于特定数据库的CREATE权限与全局CREATE权限的差异。全局CREATE权限允许创建数据库,但不包含删除数据库的权限。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CREATE权限仅仅指明用户能够创建,数据库、表和必须隐式创建的索引(比如主键索引和唯一键索引)。

当然这也要根据授权的方式不同而不同。

比如:

mysql> show grants for 'ut01'@'%';
+----------------------------------+
| Grants for ut01@%                |
+----------------------------------+
| GRANT USAGE ON *.* TO 'ut01'@'%' |
+----------------------------------+
1 row in set (0.00 sec)


mysql> grant create on test.* to 'ut01'@'%';  #这仅仅让该用户能够在test schema中创建表(和隐式索引),但是不能创建库(schema)
Query OK, 0 rows affected (0.25 sec)


mysql> show grants for 'ut01'@'%';
+----------------------------------------+
| Grants for ut01@%                      |
+----------------------------------------+
| GRANT USAGE ON *.* TO 'ut01'@'%'       |
| GRANT CREATE ON `test`.* TO 'ut01'@'%' |
+----------------------------------------+
2 rows in set (0.00 sec)


mysql>

仅仅被授予CREATE权限的用户不能alter表结构,也不能显示创建和删除索引,也不能查询和dml表,更不能drop表。

而如下方式授予的create权限:

mysql> grant create on *.* to 'ut01'@'%';
Query OK, 0 rows affected (0.04 sec)


mysql> show grants for 'ut01'@'%';
+-----------------------------------+
| Grants for ut01@%                 |
+-----------------------------------+
| GRANT CREATE ON *.* TO 'ut01'@'%' |
+-----------------------------------+
1 row in set (0.00 sec)


mysql>

实际上额外还有了创建database/schema的权限,但是不能删除database/schema。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值