宜昌本地网站,湖南速马科技有限公司,网络营销logo,和顺网站建设文章目录 一、用户管理二、用户#xff08;一#xff09;用户信息#xff08;二#xff09;创建用户1.语法#xff1a;2.案例#xff1a; #xff08;三#xff09; 删除用户1.语法#xff1a;2.示例#xff1a; #xff08;四#xff09;修改用户密码1.语法#… 文章目录 一、用户管理二、用户一用户信息二创建用户1.语法2.案例 三 删除用户1.语法2.示例 四修改用户密码1.语法 三、数据库的权限一给用户授权1.语法2.说明3.案例 二 回收权限1.语法2.示例 一、用户管理
如果我们只能使用root用户这样存在安全隐患。这时就需要使用MySQL的用户管理。
二、用户
一用户信息
MySQL中的用户都存储在系统数据库mysql的user表中。
mysql use mysql;
Database changed
mysql select host,user,authentication_string from user;字段解释
host 表示这个用户可以从哪个主机登陆如果是localhost表示只能从本机登陆user 用户名authentication_string 用户密码通过password函数加密后的*_priv 用户拥有的权限
二创建用户
1.语法
create user 用户名登陆主机/ip identified by 密码;2.案例
mysql create user whblocalhost identified by 12345678;Query OK, 0 rows affected (0.06 sec)
mysql select user,host,authentication_string from user;
---------------------------------------------------------------------
| user | host | authentication_string |
---------------------------------------------------------------------
| root | % | *A2F7C9D334175DE9AF4DB4F5473E0BD0F5FA9E75|
| mysql.session | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE|
| mysql.sys | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE|
| mt | localhost | *84AAC12F54AB666ECFC2A83C676908C8BBC381B1| --新增用户
---------------------------------------------------------------------
4 rows in set (0.00 sec)
-- 此时便可以使用新账号新密码进行登陆啦
--备注可能实际在设置密码的时候因为mysql本身的认证等级比较高一些简单的密码无法设置会爆出
如下报错
-- ERROR 1819 (HY000): Your password does not satisfy the current policy
requirements
-- 解决方案https://blog.csdn.net/zhanaolu4821/article/details/93622812
--查看密码设置相关要求SHOW VARIABLES LIKE validate_password%;三 删除用户
1.语法
drop user 用户名主机名2.示例
mysql select user,host,authentication_string from user;
mysql select user,host,authentication_string from user;
---------------------------------------------------------------------
| user | host | authentication_string |
---------------------------------------------------------------------
| root | % | *A2F7C9D334175DE9AF4DB4F5473E0BD0F5FA9E75|
| mysql.session | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE|
| mysql.sys | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE|
| mt | localhost | *84AAC12F54AB666ECFC2A83C676908C8BBC381B1| --新增用户
---------------------------------------------------------------------
4 rows in set (0.00 sec)
mysql drop user whb; --尝试删除
ERROR 1396 (HY000): Operation DROP USER failed for mt% -- 直接给个用户名
不能删除它默认是%表示所有地方可以登陆的用户
mysql drop user mtlocalhost; --删除用户
Query OK, 0 rows affected (0.00 sec)
---------------------------------------------------------------------
| user | host | authentication_string |
---------------------------------------------------------------------
| root | % | *A2F7C9D334175DE9AF4DB4F5473E0BD0F5FA9E75|
| mysql.session | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE|
| mysql.sys | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE|
| mt | localhost | *84AAC12F54AB666ECFC2A83C676908C8BBC381B1| --新增用户
---------------------------------------------------------------------
4 rows in set (0.00 sec)四修改用户密码
1.语法
自己改自己密码
set passwordpassword(新的密码);root用户修改指定用户的密码
set password for 用户名主机名password(新的密码)mysql select host,user, authentication_string from user;---------------------------------------------------------------------
| user | host | authentication_string |
---------------------------------------------------------------------
| root | % | *A2F7C9D334175DE9AF4DB4F5473E0BD0F5FA9E75|
| mysql.session | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE|
| mysql.sys | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE|
| mt | localhost | *84AAC12F54AB666ECFC2A83C676908C8BBC381B1| --新增用户
---------------------------------------------------------------------
4 rows in set (0.00 sec)mysql set password for mtlocalhostpassword(87654321);
Query OK, 0 rows affected, 1 warning (0.00 sec)mysql select host,user, authentication_string from user;---------------------------------------------------------------------
| user | host | authentication_string |
---------------------------------------------------------------------
| root | % | *A2F7C9D334175DE9AF4DB4F5473E0BD0F5FA9E75|
| mysql.session | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE|
| mysql.sys | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE|
| mt | localhost | *5D24C4D94238E65A6407DFAB95AA4EA97CA2B199| --新增用户
---------------------------------------------------------------------
4 rows in set (0.00 sec)三、数据库的权限
MySQL数据库提供的权限列表
一给用户授权
刚创建的用户没有任何权限。需要给用户授权。
1.语法
grant 权限列表 on 库.对象名 to 用户名登陆位置 [identified by 密码]2.说明
权限列表多个权限用逗号分开
grant select on ...
grant select, delete, create on ....
grant all [privileges] on ... -- 表示赋予该用户在该对象上的所有权限. : 代表本系统中的所有数据库的所有对象表视图存储过程等库.* : 表示某个数据库中的所有数据对象(表视图存储过程等)identified by可选。 如果用户存在赋予权限的同时修改密码,如果该用户不存在就是创建用户
3.案例
--使用root账号
--终端A
mysql show databases;--给用户whb赋予test数据库下所有文件的select权限
mysql grant select on test.* to whblocalhost;
Query OK, 0 rows affected (0.01 sec)--使用whb账号
--终端B二 回收权限
1.语法
revoke 权限列表 on 库.对象名 from 用户名登陆位置2.示例
-- 回收mt对test数据库的所有权限
--root身份终端A
mysql revoke all on test.* from mtlocalhost;
Query OK, 0 rows affected (0.00 sec)