mysql的权限介绍,全库,单库,单表,和列权限授予

权限有     ALL,ALTER,CREATE,DROP,SELECT,UPDATE,DELETE  

  1.    新增用户:权限为USAGE,即为:"无权限",想要创建一个没有权限的用户时,可以指定USAGE  

账户级别有

1,整个服务器,使用 grant ALL  和revoke  ALL

2,整个数据库,使用on  database.*

3,特点表,使用on  database.table

4,特定的列

5,特定的存储过程

 

如果过程出现 MySQL报错解决:The MySQL server is running with the --read-only option so it cannot execute this statement
https://www.cnblogs.com/hiit/p/11465470.html

set global read_only=0; flush privileges;

 

创建用户
CREATE USER 't1'@'10.0.2.52' IDENTIFIED BY '123456';

CREATE USER 't2'@'10.0.2.52' IDENTIFIED BY '123456';

CREATE USER 't3'@'10.0.2.52' IDENTIFIED BY '123456';

分别赋予用户,全库,单库,单表,和列权限授予
grant select(id, login_ip) on dqms.log_login to 't1'@'10.0.2.52';

GRANT all on dqms.*  TO 't2'@'10.0.2.52';

GRANT all ON *.*  TO 't3'@'10.0.2.52';

show grants for 't1'@'10.0.2.52';
show grants for 't2'@'10.0.2.52';
show grants for 't3'@'10.0.2.52';
FLUSH PRIVILEGES ;
SELECT * from mysql.`user` ;

host是指定ip连接进来

%              匹配所有主机

localhost    localhost不会被解析成IP地址,直接通过UNIXsocket连接

127.0.0.1      会通过TCP/IP协议连接,并且只能在本机访问;

::1                 ::1就是兼容支持ipv6的,表示同ipv4的127.0.0.1

 

 

授予某张表权限,权限信息保存在mysql.tables_priv表中

授予某个字段的权限,权限信息保存在mysql.columns_priv表中

 

当使用

revoke all privileges on *.* from 'test'@'localhost';

 回收的只是全局的权限,test用户其他的权限,比如对pmx数据库的权限,对score表的权限,对某个字段的权限仍然持有。 所以为了回收用户的所有权限,使用

revoke all privileges,grant option from 'test'@'localhost';

这是条固定语法,all privileges和grant option必须都有 

### 创建 MySQL 用户并授予权限MySQL 中,可以通过 `CREATE USER` `GRANT` 命令来创建新用户并将权限授予该用户。以下是具体的操作方法: #### 1. 创建新用户 要创建一个新的 MySQL 用户,可以使用以下 SQL 语句: ```sql CREATE USER 'new_user'@'localhost' IDENTIFIED BY 'password'; ``` 此命令会创建一个名为 `new_user` 的用户,并设置其密码为 `password`。这里的 `'localhost'` 表示只有来自本地主机的连接才被允许访问[^2]。 #### 2. 授予特定数据库权限 为了向用户授予对某个特定数据库权限,可以使用 `GRANT` 语句。例如,如果希望用户能够完全控制某数据库(即拥有所有的权限),可以执行如下命令: ```sql GRANT ALL PRIVILEGES ON my_database.* TO 'new_user'@'localhost'; ``` 上述命令中的 `ALL PRIVILEGES` 可替换为更具体的权限类型,比如 `SELECT`, `INSERT`, 或者其他操作权限[^4]。通过指定 `my_database.*`,表示仅对该数据库下的所有表赋予相应的权限。 #### 3. 刷新权限 完成权限分配之后,建议运行下面这条指令以确保更改立即生效: ```sql FLUSH PRIVILEGES; ``` 这样做的目的是通知服务器重新加载存储于内存中的授权表数据结构,从而应用最新的修改[^3]。 ### 示例代码 假设我们需要建立一名叫做 testuser 并给予它针对 exampledb 数据库读写权利,则完整的脚本可能看起来像这样: ```sql -- Step 1: Create the user. CREATE USER 'testuser'@'localhost' IDENTIFIED BY 'secure_password'; -- Step 2: Assign read/write privileges on specified db. GRANT SELECT, INSERT, UPDATE, DELETE ON exampledb.* TO 'testuser'@'localhost'; -- Step 3: Make sure changes take place instantly. FLUSH PRIVILEGES; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值