OceanBase数据库-学习笔记5-用户

用户相关命令

命令 描述
CREATE USER 'username'@'host' IDENTIFIED BY 'password'; 创建用户。
GRANT ALL PRIVILEGES ON database_name.* TO 'test_user'@'%'; 给用户授权所有权限。
GRANT SELECT, INSERT, UPDATE ON database_name.* TO 'test_user'@'%'; 给用户授权指定权限。
SHOW GRANTS FOR 'test_user'@'%'; 查看用户权限。
DROP USER 'test_user'@'%'; 删除用户。

1. 创建用户

  • Sql: CREATE USER 'username'@'host' IDENTIFIED BY 'password';

    • username:要创建的用户名。
    • host:允许用户连接的主机。可以使用 % 表示允许从任意主机连接,或者指定具体的 IP 地址或主机名。
    • password:用户的密码。
  • 案例:创建用户fenghx,并只允许该用户从本地访问数据库

    obclient [oceanbase]> CREATE USER 'testuser'@'%' IDENTIFIED BY '123456';
    Query OK, 0 rows affected (0.206 sec)

    obclient [oceanbase]>

2. 为用户授予权限

创建用户后,通常需要为用户授予权限。可以使用 GRANT 语句为用户授予权限。

授予所有权限
  • Sql: GRANT ALL PRIVILEGES ON database_name.* TO 'test_user'@'%';FLUSH PRIVILEGES;
    • 将 database_name 替换为具体的数据库名称。
    • ALL PRIVILEGES 表示授予所有权限。
    • FLUSH PRIVILEGES 用于刷新权限,使更改立即生效。
授予特定权限
  • Sql: GRANT SELECT, INSERT, UPDATE ON database_name.* TO 'test_user'@'%';FLUSH PRIVILEGES;
    • 授予用户 SELECT、INSERT 和 UPDATE 权限。
查看用户权限

创建用户并授予权限后,可以通过以下 SQL 查询查看用户的权限。

  • Sql: SHOW GRANTS FOR 'test_user'@'%';
    • 该查询会返回用户 test_user 的权限信息。

9. 删除用户

如果需要删除用户,可以使用 DROP USER 语句。

  • DROP USER 'test_user'@'%';

其他

1. 查询当前用户返回root@%,这个%符号是什么意思

复制代码
obclient [oceanbase]> select CURRENT_USER();
+----------------+
| CURRENT_USER() |
+----------------+
| root@%         |
+----------------+
1 row in set (0.001 sec)

obclient [oceanbase]>

在数据库(如 MySQL、OceanBase 等)中,root@% 表示一个用户名为 root 的用户,且其访问权限适用于 所有主机(即 % 是通配符,表示任意主机)。

1. root@% 的含义

  • root:用户名。
  • %:主机名通配符,表示允许从任何主机连接到数据库。

例如:

  • root@% 表示用户 root 可以从任何主机连接到数据库。
  • root@localhost 表示用户 root 只能从本地主机(localhost)连接到数据库。
  • [email protected] 表示用户 root 只能从 IP 地址为 192.168.1.100 的主机连接到数据库。

2. 为什么需要 % 通配符?

在数据库权限管理中,用户权限通常与用户名和主机名绑定。% 通配符的作用是允许用户从任意主机访问数据库,这在以下场景中非常有用:

  • 远程访问数据库。
  • 在分布式系统中,多个节点需要连接到同一个数据库。

2. 查看用户登录权限

在 MySQL 或 OceanBase 中,可以通过以下 SQL 查询查看用户及其主机权限:

  • 查询用户权限

SELECT user, host FROM mysql.user; # 该查询会返回所有用户及其允许访问的主机。

复制代码
obclient [oceanbase]> SELECT user, host FROM mysql.user;
+-------------+------+
| user        | host |
+-------------+------+
| root        | %    |
| proxyro     | %    |
| ocp_monitor | %    |
+-------------+------+
3 rows in set (0.008 sec)

obclient [oceanbase]>

以上就是本次的分享,感谢阅读。

上一章:《OceanBase数据库-学习笔记4-租户》

下一章:《OceanBase数据库-学习笔记6-查询小技巧》

相关推荐
日日行不惧千万里35 分钟前
数据库故障排查指南
网络·数据库·oracle
superior tigre37 分钟前
C++学习:六个月从基础到就业——C++11/14:其他语言特性
c++·学习
神秘敲码人43 分钟前
Django基础(二)Django 项目基础操作
数据库·笔记·django
程序员Bears1 小时前
电商后台管理系统:Django Admin深度定制实战指南
数据库·django·sqlite
神秘敲码人1 小时前
Django基础(一)MVT 模式与 Django 框架
笔记·python·django
TDengine (老段)1 小时前
TDengine 2025年产品路线图
大数据·数据库·动态规划·时序数据库·tdengine·涛思数据
虾球xz1 小时前
游戏引擎学习第288天:继续完成Brains
c++·学习·游戏引擎
Y3174291 小时前
Python Day27 学习
python·学习·机器学习
Aurora_NeAr1 小时前
Redis设计与实现——分布式Redis
数据库·redis·分布式
bst@微胖子1 小时前
DeepSeek提示工程Prompt Engineering
java·数据库·prompt