MySQL中的用户创建与权限管理
作者:郭怀远 发布时间:2024-01-17 00:49:06
一、用户管理
在mysql
库里有个user表
可以查看已经创建的用户
1.创建MySQL用户
注意:MySQL中不能单纯通过用户名来说明用户,必须要加上主机。如hhy@10.1.1.1
基本语法:
mysql> create user '用户名'@'被允许连接的主机名称或主机的IP地址' identified by '用户密码';
mysql> select user,host from mysql.user;
案例:创建一个MySQL账号,用户名:hhy,用户密码:123
mysql> create user 'hhy'@'localhost' identified by '123';
/*或*/
mysql> create user 'hhy'@'127.0.0.1' identified by '123';
案例:创建一个MySQL账号(要求开通远程连接),主机IP地址:192.1668.44.110,用户名:test,用户密码:123
mysql> create user 'test'@'192.1668.44.110' identified by '123';
测试:在IP地址为192.168.44.110的主机上
# yum install mysql -y
# mysql -h 192.168.44.110 -P 3306 -uharry -p
Enter password:123
选项说明:192.168.44.110 :MySQL服务器端的IP地址
yum安装mysql:代表安装的是MySQL的客户端
yum安装mysql-server:代表安装的是MySQL的服务器端
案例:创建一个MySQL账号(要求开通远程连接),主机IP的网段:10.1.1.0,用户名:jack,用户密码:123
create user 'jack'@'192.168.44.%' identified by '123'
案例:创建一个MySQL账号(要求开通远程连接),要求面向所有主机开放,用户名:root,用户密码:123
create user 'root'@'%' identified by '123';
2. 删除MySQL用户
基本用户:
mysql> drop user '用户名'@'主机名称或主机的IP地址';
特别说明:
如果在删除用户时没有指定主机的名称或主机的IP地址,则默认删除这个账号的所有信息。
案例:删除hhy这个账号
drop user 'hhy'@'localhost';
案例:删除jack这个账号
drop user 'jack'@'192.168.44.%';
案例:创建两个harry账号(localhost/10.1.1.23),然后删除其中的某个
mysql> create user 'harry'@'localhost' identified by '123';
mysql> create user 'harry'@'192.168.44.110' identified
mysql> drop user 'harry'@'192.168.44.110';
删除MySQL账号的另外一种方式
mysql> delete from mysql.user where user='root' and host='%';
mysql> flush privileges;
3. 修改MySQL用户
特别说明:MySQL用户重命名通常可以更改两部分,一部分是用户的名称,一部分是被允许访问的主机名称或主机的IP地址。
基本语法:
mysql> rename user 旧用户信息 to 新用户信息;
案例:把用户’root’@'%‘更改为’root’@‘10.1.1.%’
mysql> rename user 'root'@'%' to 'root'@'10.1.1.%';
案例:把’harry’@‘localhost’更名为’hhy’@‘localhost’
mysql> create user 'tom'@'localhost' identified by '123';
mysql> rename user 'tom'@'localhost' to 'hhy'@'localhost';
使用update语句更新用户信息
mysql> update mysql.user set user='hhy',host='localhost' where user='tom' and host='localhost';
mysql> flush privileges;
二、权限管理
1. 权限说明
所有权限说明
USAGE无权限,只有登录数据库,只可以使用test或test_*数据库
ALL所有权限
以下权限为指定权限
select/update/delete/super/replication slave/reload...
with grant option 选项表示允许把自己的权限授予其它用户或者从其他用户收回自己的权限
默认情况下,分配权限时如果没有指定with grant option,代表这个用户不能下发权限给其他用户,但是这个权限分配不能超过自身权限。
2. 权限保存位置(了解)
mysql.user:所有mysql用户的账号和密码,以及用户对全库全表权限(*.*)
mysql.db :非mysql库的授权都保存在此(db.*)
mysql.table_priv :某库某表的授权(db.table)
mysql.columns_priv :某库某表某列的授权(db.table.col1)
mysql.procs_priv :某库存储过程的授权
3. 给用户授权
创建数据库表:
create database java;
use java;
create table tb_student(
id mediumint not null auto_increment,
name varchar(20),
age tinyint unsigned default 0,
gender enum('男','女'),
address varchar(255),
primary key(id)
) engine=innodb default charset=utf8;
insert into tb_student values (null,'刘备',33,'男','湖北省武汉市');
insert into tb_student values (null,'貂蝉',18,'女','湖南省长沙市');
insert into tb_student values (null,'关羽',32,'男','湖北省荆州市');
insert into tb_student values (null,'大乔',20,'女','河南省漯河市');
insert into tb_student values (null,'赵云',25,'男','河北省石家庄市');
insert into tb_student values (null,'小乔',18,'女','湖北省荆州市');
基本语法:
mysql> grant 权限1,权限2 on 库.表 to 用户@主机
mysql> grant 权限(列1,列2,...) on 库.表 to 用户@主机
库.表表示方法:*.*代表所有数据库的所有数据表,db_itheima.*代表db_itheima数据库中的所有数据表,db_itheima.tb_admin,代表db_itheima数据库中的tb_admin表
案例:给thhy账号分配java数据库的查询权限
mysql> grant select on java.* to 'hehanyu'@'192.168.44.%';
mysql> flush privileges;
案例:给hehanyu账号分配java.tb_student数据表的权限(要求只能更改age字段)
mysql> grant update(age) on java.tb_student to 'hehanyu'@'192.168.44.%';
mysql> flush privileges;
案例:添加一个root@%账号,然后分配所有权限
create user 'root'@'%' identified by '123';
grant all on *.* to 'root'@'%';
flush privileges;
4. 查询用户权限
查询当前用户权限:
mysql> show grants;
查询其他用户权限:
mysql> show grants for '用户名称'@'授权的主机名称或IP地址';
5. with grant option选项
mysql> grant all on *.* to 'amy'@'10.1.1.%' identified by '123' with grant option;
mysql> grant all on *.* to 'harry'@'10.1.1.%' identified by '123';
如以上命令所示:amy拥有下发权限的功能,而harry不具备下发权限的功能。
如果grant授权时没有with grant option选项,则其无法为其他用户授权。
6.revoke回收权限
基本语法:
revoke 权限 on 库.表 from 用户;
查看hehanyu用户权限
mysql> show grants for 'hehanyu'@'192.168.44.%';
撤消指定的权限
mysql> revoke update on java.tb_student from 'tom'@'192.168.44.%';
撤消所有的权限
mysql> revoke select on java.* from 'tom'@'192.168.44.%';
来源:https://blog.csdn.net/weixin_53946852/article/details/126590635


猜你喜欢
- 原文件:7.8094,1.0804,5.7632,0.012269,0.008994,-0.003469,-0.79279,-0.06468
- 前言最近补 Golang channel 方面八股的时候发现用 channel 实现一个优雅退出功能好像不是很难,之前写的 HTTP 框架刚
- 本文实例讲述了Python enumerate函数功能与用法。分享给大家供大家参考,具体如下:eunmerate在英文中是列举、枚举的意思,
- 1、打开文件open()函数简介 :打开文件使用open函数,可以打开一个已经存在的文件,如果没有这个文件的话,会创建一个新文件完整的语法格
- 使用PHP开发应用程序,尤其是网站程序,常常需要生成随机密码,如用户注册生成随机密码,用户重置密码也需要生成一个随机的密码。随机密码也就是一
- 目录一、线程基础以及守护进程二、线程锁(互斥锁)三、线程锁(递归锁)四、死锁五、队列六、相关面试题七、判断数据是否安全八、进程池 &
- 本实例使用的mysql版本为mysql-8.0.15-winx641、下载zip包官网地址:https://dev.mysql.com/do
- Mac本地环境搭建在Mac系统,我们可以使用MAMP Pro (官方网站:https://www.mamp.info/en/)软件来搭建本地
- 最近做一个车牌识别项目,入门级别的,十分简单。车牌识别总体分成两个大的步骤:一、车牌定位:从照片中圈出车牌二、车牌字符识别这里只说第二个步骤
- 本文实例讲述了创建Django项目的方法。分享给大家供大家参考,具体如下:创建Django项目创建一个HelloDjango项目GitHub
- 问题描述初步使用PyTorch进行平方根计算,通过range()创建一个张量,然后对其求平方根。a = torch.tensor(list(
- 通过观察执行计划,发现之前的执行计划在很多大表连接的部分使用了Hash Join,由于涉及的表中数据众多,因此查询优化器选择使用并行执行,速
- 数据完整性是任何数据库系统要保证的重点。不管系统计划得有多好,空数据值的问题总是存在。本文探讨了在SQL Server中处理这些值时涉及的3
- <html> <head> <meta http-equiv="Content-Type"
- 如下所示:device = torch.device("cuda:0" if torch.cuda.is_availab
- PPOCRLabel标注的txt格式转换成labelme能修改的json格式PPOCR是个好东西默认的训练文件是用自带的PPOCRLabel
- javascript是种脚本语言,浏览器下载到哪儿就会执行到哪儿,这种特性会为编程提供方便,但也容易使程序过于凌乱,支离破碎。 js从功能上
- 实例如下:from win32com.client import Dispatch import win32com.client
- 在 python 中除了用 opencv,也可以用 matplotlib 和 PIL 这两个库操作图片。本人偏爱 matpoltlib,因为
- 喜欢用 Python 做项目的小伙伴不免会遇到这种情况:做图表时,用哪种好看又实用的可视化工具包呢?之前文章里出现过漂亮的图表时,也总有读者