mysql 对象权限设置_MYSQL用户管理及权限设置

MySQL的访问控制包括用户管理和访问控制模块,用户信息存储在mysql.user表中。创建、重命名、删除用户需要相应的SQL命令,并用flush privileges使更改生效。权限包括全局、数据库、表、列和存储例程等不同级别,常见的权限类型有SELECT、INSERT、UPDATE等。通过grant和revoke命令授予或废除用户权限,show grants命令可查看用户权限。
摘要由CSDN通过智能技术生成

MySQL的整个访问控制包括两大块:用户管理模块、访问控制模块

4336067e795e40930d511880cdf23580.png

用户登录并不属于访问控制机制,而是用户身份识别和认证,认证包括主机名、用户名及密码

用户管理模块的信息存储在系统表mysql.user中

9be995256e9136307e41cc35ae9dfd94.png

创建用户

b7c84483df00e747cac9580324df4c49.png

用户重命名

30bdc3ec129414c583c8a6a9acdd7802.png

更改密码

93018f112afbba06224f55b6e6cc0ac6.png

删除用户(drop user '用户名'@'主机名')

ccd34f3b7d4cc36462e133e4f89afc5e.png

在更改密码,修改权限的时候,必须使用刷新命令flush privileges

flush privileges 命令本质上的作用是将当前user和privilige表中的用户信息/权限设置从mysql库(MySQL数据库的内置库)中提取到内存里。MySQL用户数据和权限有修改后,希望在"不重启MySQL服务"的情况下直接生效,那么就需要执行这个命令。通常是在修改ROOT帐号的设置后,怕重启后无法再登录进来,那么直接flush之后就可以看权限设置是否生效。而不必冒太大风险。

MySQL授权

权限可分为权限类型和权限对象,如用户u1可以查看数据库d1中的表t1的所有内容,权限类型就是select,权限对象就是表t1。

基本格式:grant 权限类型 on 权限对象 to '用户名'@'主机名';

71543eea0a8ce75cbd2cbd27db639456.png

权限级别:

①全局权限Global Privileges:管理权限,应用到服务器上的所有数据库上(全局权限保存在 mysql.user 表中)-----on *.*

②数据库权限Database Privileges:应用到某个特定数据库的所有对象上(数据库权限保存在 mysql.db 表中)-----on db_name.*

③表权限Table Privileges:应用到某个特定表的所有列上(表权限保存在 mysql.tables_priv 表中)-----on db_name.tbl_name

④列权限Column Privileges:应用到某个特定表的单个列上(列权限保存在 mysql.columns_priv 表中)-----在权限名称后面跟小括号,其中写上列名

⑤存储例程权限Stored Routine Privileges:应用到存储过程和函数上(存储例程权限保存在 mysql.procs_priv表中)

⑥代理用户权限Proxy User Privileges:使一个用户成为另一个用户的代理(代理用户权限保存在 mysql.proxies_priv表中)

权限类型:

1>.all/all privileges权限

代表全局或者全数据库对象级别的所有权限。

2>.alter权限

代表允许修改表结构的权限,但必须要求有create和insert权限配合。如果是rename表名,则必须要求有alter和drop原表,create和insert新表的权限。

3>.alter routine权限

代表允许修改或者删除存储过程,函数的权限。

4>.create权限

create权限代表允许创建新的数据库和表的权限。

5>.create routine权限

代表允许创建存储过程,函数的权限。

6>.create tablespace权限

代表允许创建,修改,删除表空间和日志组的权限。

7>.crate tempoary tables权限

代表允许创建临时表的权限。

8>.create user权限

代表允许创建,修改,删除,重命名usrer的权限。

9>.create view权限

代表允许创建视图的权限。

10>.delete权限

代表允许删除行数据的权限。

11>.drop权限

代表允许删除数据库,表,视图的权限,包括truncate table命令。

12>.event权限

代表允许查询,创建,修改,删除mysql事件。

13>.execute权限

代表允许执行存储过程和函数的权限。

14>.file权限

代表允许在mysql可以访问的目录进行读写磁盘文件操作,可使用的命令包括load data infile,select ... into outfile,load file()函数。

15>.grant option权限

代表是否允许此用户授权或者收回其他用户你给予的权限。

16>.index权限

代表是否允许创建和删除索引。

17>.insert权限

代表是否允许在表里插入数据,同时在执行analyze table,optimize table,repair table语句的时候也需要insert权限。

18>.lock权限

代表允许对拥有select权限的表进行锁定,以防止其他链接对此表的读或写。

19>.process权限

代表允许查看mysql中的进程信息,比如执行show processlist,mysqladmin processlist(命令行),show engines等命令。

20>.reference权限

是在5.7.6版本之后引入,代表是否允许创建外键。

21>.reload权限

代表允许执行flush命令,指明重新家在权限表到系统内存中,refresh命令代表关闭和重新开启日志文件并刷新所有到表。

22>.replication client权限

代表允许执行show master status,show slave status,show binary logs命令。

23>.replication slave权限

代表允许slave主机通过此用户连接master以便建立主从复制关系。

24>.select权限

代表允许从表中查看数据,某些不查询表数据的select执行则不需要此权限,如select 1+1,select pi() +5等等;而且select权限在执行updata/delete语句中含有where条件的情况下也是需要的。

25>.show databases权限

代表通过执行show databases名称查看所有的数据库名。

26>.show view权限

代表通过执行show create view命令查看视图创建的语句。

27>.shutdown权限

代表允许关闭数据库实例,执行语句包括mysqladmin shutdown。

28>.super权限

代表允许执行一系列数据库管理命令,包括kill强制关闭某个连接命令,change master to创建复制关系命令,以及crete/alter/drop server等命令。

29>.trigger权限

代表允许创建,删除,执行,现实触发器等权限。

30>.upadte权限

代表允许修改表中等数据等权限。

31>.usage权限

它是创建一个用户之后等默认权限,其本身代表连接登陆权限。

废除权限

格式:revoke 权限类型 on 权限对象 from '用户名'@'主机名';

查看权限

格式:show grants for '用户名'@'主机名';

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值