mysql 创建用户 授予权限

本文介绍如何在MySQL中创建用户、设置权限、修改密码、撤销权限及删除用户等基本操作。
一, 创建用户:

命令:CREATE USER 'username'@'host' IDENTIFIED BY 'password';

说明:username - 你将创建的用户名, host - 指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost, 如果想让该用户可以从任意远程主机登陆,可以使用通配符%. password - 该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器.

例子: CREATE USER 'dog'@'localhost' IDENTIFIED BY '123456';
CREATE USER 'pig'@'192.168.1.101_' IDENDIFIED BY '123456';
CREATE USER 'pig'@'%' IDENTIFIED BY '123456';
CREATE USER 'pig'@'%' IDENTIFIED BY '';
CREATE USER 'pig'@'%';


 create user 'countuser'@'%' identified by 'count1234';



二,授权:

命令:GRANT privileges ON databasename.tablename TO 'username'@'host'

说明: privileges - 用户的操作权限,如SELECT , INSERT , UPDATE 等.如果要授予所的权限则使用ALL.;databasename - 数据库名,tablename-表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示, 如*.*.

例子: GRANT SELECT, INSERT ON test.user TO 'pig'@'%';
GRANT ALL ON *.* TO 'pig'@'%';

注意:用以上命令授权的用户不能给其它用户授权,如果想让该用户可以授权,用以下命令:
GRANT privileges ON databasename.tablename TO 'username'@'host' WITH GRANT OPTION;


例子:
grant select on *.* to 'countuser'@'count1234';

三.设置与更改用户密码

命令:SET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');如果是当前登陆用户用SET PASSWORD = PASSWORD("newpassword");

例子: SET PASSWORD FOR 'pig'@'%' = PASSWORD("123456");

也可:
mysql> UPDATE user SET password=PASSWORD("new password") WHERE user='name'; 
  mysql> FLUSH PRIVILEGES; 
  mysql> QUIT 

四.撤销用户权限

命令: REVOKE privilege ON databasename.tablename FROM 'username'@'host';

说明: privilege, databasename, tablename - 同授权部分.

例子: REVOKE SELECT ON *.* FROM 'pig'@'%';

注意: 假如你在给用户'pig'@'%'授权的时候是这样的(或类似的):GRANT SELECT ON test.user TO 'pig'@'%', 则在使用REVOKE SELECT ON *.* FROM 'pig'@'%';命令并不能撤销该用户对test数据库中user表的SELECT 操作.相反,如果授权使用的是GRANT SELECT ON *.* TO 'pig'@'%';则REVOKE SELECT ON test.user FROM 'pig'@'%';命令也不能撤销该用户对test数据库中user表的Select 权限.

具体信息可以用命令SHOW GRANTS FOR 'pig'@'%'; 查看.

五.删除用户

命令: DROP USER 'username'@'host';
### 创建 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; ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值