iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL用户和数据权限管理详解
  • 302
分享到

MySQL用户和数据权限管理详解

2024-04-02 19:04:59 302人浏览 安东尼
摘要

目录1、管理用户1.1、添加用户1.2、删除用户1.3、修改用户名1.4、修改密码2、授予权限和回收权限2.1、授予权限2.2、权限的转移和限制2.3、回收权限1、管理用户 1.1、添加用户 可以使用CREATE USE

1、管理用户

1.1、添加用户

可以使用CREATE USER语句添加一个或多个用户,并设置相应的密码

语法格式:

CREATE USER 用户名 [IDENTIFIED BY [PASSWord]'密码']

CREATE USER用于创建新的Mysql账户。CREATE USER会在系统本身的mysql数据库的user表中添加一个新记录。要使用CREATE USER,必须拥有mysql数据库的全局CREATE USER权限或INSERT权限。如果账户已经存在,则出现错误(报错)。

例:添加一个新用户usr1,密码为123456 

CREATE USER usr1@localhost IDENTIFIED BY'123456';

在用户名的后面声明了关键字localhost。该关键字指定用户创建所使用的MySQL服务器来自于主机。如果一个用户名和主机名中包含特殊符号_或通配符%,则需要用单引号将其括起,%表示一组主机。

1.2、删除用户

语法格式:

DROP USER 用户名

要使用该语句,必须有mysql数据库的全局CREATE USER权限或DELETE权限。DROP USER语句用于删除一个或多个MySQL账户,并取消其权限。

例:删除用户usr1 

DROP USER usr1@localhost;

1.3、修改用户名

语法格式:

RENAME USER 旧用户名 TO 新用户名

要使用该语句,必须有全局CREATE USER权限或mysql数据库的UPDATE权限。如果旧账户不存在或者新账户已存在,则会出现错误(报错)。该语句用于对原有MySQL账户进行重命名,可以一次对多个用户更名。

例:将用户usr1和usr2的名字分别修改为user1和user2 

RENAME USER
usr1@localhost TO user1@localhost,
usr2@localhost TO user2@localhost;

1.4、修改密码

语法格式:

SET PASSWORD [ FOR 用户名 ]=PASSWORD('新密码')

如果不加FOR用户名,表示修改当前用户的密码。加了FOR用户名则是修改当前主机上的特定用户的密码。用户名的值必须以user_name@host_name的格式给定。

例:将用户user1的密码修改为king 

SET PASSWORD FOR user1@localhost=PASSWORD('king');

2、授予权限和回收权限

2.1、授予权限

新的SQL用户不允许访问属于其他SQL用户的表,也不能立即创建自己的表,它必须被授权,可以授予的权限有以下几组:

1、列权限:和表中的一个具体列相关。例如,使用UPDATE语句更新表Book书号列值的权限。

2、表权限:和一个具体表中的所有数据相关。例如,使用SELECT语句查询表Book所有数据的权限。

3、数据库权限:和一个具体的数据库中所有表相关。例如,在已有的Bookstore数据库中创建新表的权限。

4、用户权限:和MySQL所有的数据库相关。例如,删除已有的数据库或者创建一个新数据库的权限。

给某用户授予权限可以使用GRANT语句。使用SHOW GRANTS语句可以查看当前账户拥有的权限。

语法格式:

GRANT 权限1[(列名列表1)][,权限2[(列名列表2)]...
ON [目标]{表名 | * | *.* | 库名.*}
TO 用户1 [IDENTIFIED BY [PASSWORD]'密码1']
[,用户2 [IDENTIFIED BY [PASSWORD]'密码2']]...
[WITH 权限限制1[权限限制2]...]

2.1.1、授予表权限

授予表权限时,权限可以是以下值:

1、SELECT:授予用户使用SELECT语句访问特定表(或视图)的权力。对于视图,用户必须对视图中指定的每个表(或视图)都有SELECT权限。

2、INSERT:授予用户使用INSERT语句向一个特定表中添加行的权力

3、DELETE:授予用户使用DELETE语句向一个特定表中删除行的权力

4、UPDATE:授予用户使用UPDATE语句修改特定表中值的权力

5、REFERENCES:授予用户创建一个外键来参照特定的表的权力

6、CREATE:授予用户使用特定的名字创建一个表的权力

7、ALTER:授予用户使用ALTER TABLE语句修改表的权力

8、INDEX:授予用户在表上定义索引的权力

9、DROP:授予用户删除表的权力

10、ALL或ALL PRIVILEGES:表示所有权限

在授予表权限时,ON关键字后面跟表名,指定授予权限的为表名或视图名

例:授予用户user1在Book表上的SELECT权限 

USE Bookstore;
GRANT SELECT
ON Book
TO user1@localhost;

这里假设是在root用户输入了这些语句,这样用户user1就可以使用SELECT语句来查询Book表,而不管是谁创建了该表。

若在TO子句中给存在的用户指定密码,则新密码将原密码覆盖。如果权限授予了一个不存在的用户,MySQL会自动执行一条CREATE USER语句来创建这个用户,但必须为该用户指定密码。

例:用户liu和zhang不存在,授予他们在Book表上的SELECT和UPDATE权限 

GRANT SELECT,UPDATE
ON Book
TO liu@localhost IDENTIFIED BY'123456',
zhang@localhost IDENTIFIED BY'123';

2.1.2、授予列权限

对于列权限,权限的值只能取SELECT、INSERT和UPDATE。权限的后面需要加上列名列表。

例:授予user1在Book表上的图书编号列和书名列的UPDATE权限。

GRANT UPDATE(图书编号,书名)
ON Book
TO user1@localhost;

2.1.3、授予数据库权限

表权限适用于一个特定的表,MySQL还支持针对整个数据库的权限。授予数据库权限时,权限可以是以下值:

1、SELECT:授予用户使用SELECT语句访问特定数据库中所有表和视图的权力

2、INSERT:授予用户使用INSERT语句向特定数据库所有表中添加行的权力

3、DELETE:授予用户使用DELETE语句在特定数据库所有表中删除行的权力

4、UPDATE:授予用户使用UPDATE语句更新特定数据库所有表中值的权力

5、REFERENCES:授予用户创建指向特定数据库中的表外键的权力

6、CREATE:授予用户使用CREATE TABLE语句在特定数据库中创建新表的权力

7、ALTER:授予用户使用ALTER TABLE语句修改特定数据库中所有表的结构的权力

8、INDEX:授予用户在特定数据库中的所有表上定义和删除索引的权力

9、DROP:授予用户删除特定数据库中所有表和视图的权力

10、CREATE TEMPORARY TABLES:授予用户在特定数据库中创建临时表的权力

11、CREATE VIEW:授予用户在特定数据库中创建新视图的权力

12、SHOW VIEW:授予用户查看特定数据库中已有视图的视图定义的权力

13、CREATE ROUTINE:授予用户为特定数据库创建存储过程和存储函数的权力

14、ALTER ROUTINE:授予用户更新和删除数据库中已有存储过程和存储函数的权力

15、EXECUTE ROUTINE:授予用户调用特定数据库的存储过程和存储函数的权力

16、LOOK TABLES:授予用户定特定数据库中已有表的权力

17、ALL或ALL PRIVILEGES:表示以上所有权限

在GRANT语法格式中,授予数据库权限时ON关键字后面跟*和“库名.*”。*表示当前数据库中的所有表。“库名.*”表示某个数据库中的所有表。

例:授予user1在Bookstore数据库中所有表的SELECT权限 

GRANT SELECT
ON Bookstore.*
TO user1@localhost;

2.1.4、授予用户权限

最有效率的权限就是用户权限,可以将授予数据库的权限直接授予用户,使用户获得对服务器上所有数据库的该权限。

MySQL授予用户权限时权限还可以是以下值:

1、CREATE USER:授予用户创建和删除新用户的权限

2、SHOW DATABASES:授予用户使用SHOW DATABASES语句查看所有已有数据库的定义的权力

在GRANT语法格式中,授予用户权限时ON子句中使用“*.*”,表示所有数据库的所有表

例:授予user2对所有数据库中所有表的CREATE、ALTERT和DROP权限 

GRANT CREATE,ALTER,DROP
ON *.*
TO user2@localhost IDENTIFIED BY'123456';

例:授予user2创建新用户的权限

GRANT CREATE USER
ON *.*
TO user2@localhost;

2.2、权限的转移和限制

GRANT语句的最后可以使用WITH子句。如果指定权限限制为GRANT OPTioN,则表示TO子句中指定的所有用户都有把自己所拥有的权限授予其他用户的权力,而不管其他用户是否拥有该权限。

 例:授予user3在Book表上的SELECT权限,并允许其将该权限授予其他用户

GRANT SELECT
ON Bookstore.Book
TO user3@localhost IDENTIFIED BY'123456'
WITH GRANT OPTION;

使用了WITH GRANT OPTION子句后,如果user3在该表上还拥有其他权限,他可以将其他权限也授予其他用户而不仅限于SELECT。

WITH子句后的权限限制也可以对一个用户授予使用限制,其中,MAX_QUERIES_PER_HOUR次数表示每小时可以查询数据库的次数。

MAX_CONNECTIONS_PER_HOUR次数表示每小时可以连接数据库的次数。

MAX_UPDATES_PES_HOUR次数表示每小时可以修改数据库的次数。

MAX_USER_CONNECTIONS次数表示同时连接MySQL的最大用户数。

次数是一个数值,对于前3个权限限制指定,次数如果为0则表示不起限制作用。

例:授予D每小时只能处理一条SELECT语句的权限 

GRANT SELECT
ON Book
TO D@localhost
WITH MAX_QUERIES_PER_HOUR 1;

2.3、回收权限

要从一个用户回收权限,但不从mysql数据库的user表中删除该用户,可以使用REVOKE语句,该语句和GRANT语句格式相似,但具有相反的效果。要使用REVOKE语句,用户必须拥有mysql数据库的全局CREATE USER权限或UPDATE权限。

语法格式:

REVOKE 权限[(列名列表)]...
ON {表名 | * | *.* | 库名.* }
FROM 用户...  

REVOKE ALL PRIVILEGES,GRANT OPTION FROM 用户

第一种格式用来回收用户的某些特定权限,第二种格式回收用户的所有权限

例:回收用户user在Book表上的SELECT权限

REVOKE SELECT
ON Book
FROM user@localhost;

到此这篇关于MySQL用户和数据权限管理详解的文章就介绍到这了,更多相关MySQL权限管理内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL用户和数据权限管理详解

本文链接: https://www.lsjlt.com/news/33839.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL用户和数据权限管理详解
    目录1、管理用户1.1、添加用户1.2、删除用户1.3、修改用户名1.4、修改密码2、授予权限和回收权限2.1、授予权限2.2、权限的转移和限制2.3、回收权限1、管理用户 1.1、添加用户 可以使用CREATE USE...
    99+
    2022-08-25
  • 详解MySQL 用户权限管理
    前言:  不清楚各位同学对数据库用户权限管理是否了解,作为一名 DBA ,用户权限管理是绕不开的一项工作内容。特别是生产库,数据库用户权限更应该规范管理。本篇文章将会介绍下 MySQL 用户权限管理相关内容...
    99+
    2022-05-30
    MySQL 权限管理 MySQL 用户权限
  • MySQL用户与权限的管理详解
    本文实例讲述了MySQL用户与权限的管理。分享给大家供大家参考,具体如下: 用户连接到MySQL,可以做各种查询,这都是MySQL用户与权限功能在背后维持着操作。 用户与数据库服务器交互数据,分为两个阶...
    99+
    2022-10-18
  • 数据库 之 MySQL用户和权限管理
    1  概述MySQL用户和权限管理 遵循最小权限授权法则,保证系统的安全性本文主要讲解关于用户MySQL用户和权限管理的相关概念和操作3  MySQL权限类别库级别:对某些库拥有对应的权...
    99+
    2022-10-18
  • MySQL数据库用户权限管理
    目录1、用户管理1.1、创建用户1.2、删除用户1.3、修改用户密码2、权限管理2.1、授予权限 grant2.2、取消权限 revoke2.3、刷新权限 flush3、密码丢失的解...
    99+
    2022-11-13
  • MySQL 用户和权限管理
    Mysql修改密码的方式如果忘记密码--skip-grant-tables 1、alter user alter user test@'localhost&#...
    99+
    2022-10-18
  • MySQL数据库用户权限如何管理
    这篇文章主要介绍“MySQL数据库用户权限如何管理”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL数据库用户权限如何管理”文章能帮助大家解决问题。1、用户管理mysql的用户信息保存在了my...
    99+
    2023-07-02
  • MYSQL用户权限管理
    1.在MySQL中,用户是怎么定义的 #mysql中,定义一个用户是: 用户名@‘主机域‘ #用户名写法: 用户名如果是字符: mysql> create user [email protected]‘10.0.0.1‘; 用户...
    99+
    2015-02-26
    MYSQL用户权限管理 数据库入门 数据库基础教程
  • MySQL创建用户和权限管理
    转自:https://www.cnblogs.com/zhaohaiyu/p/11459613.html 一、如何创建用户和密码 1.进入到mysql数据库下 mysql> use mysql Database changed ...
    99+
    2020-05-26
    MySQL创建用户和权限管理
  • MongoDB数据库权限管理详解
    前几天网友问MongoDB数据库权限方面的问题。当时大致的了解了一下,这周仔细了解了一下。对于一个数据库不可能随意的访问,肯定要有写访问限制。 在了解这个之前首先熟悉下shell客户端。打开shell客户端的方法:mon...
    99+
    2022-07-07
    MongoDB数据库 权限管理
  • SQL Server权限管理和数据恢复详解
    Microsoft公司的SQL Server是企业中广泛使用的数据库,现在很多的电子商务网站、企业信息化等都是基于SQL Server进行搭建部署的。随着网络的不断发展,非法用户技术的日益增长,针对SQL ...
    99+
    2022-10-18
  • MySQL的用户和权限如何管理
    下面讲讲关于MySQL的用户和权限如何管理,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完MySQL的用户和权限如何管理这篇文章你一定会有所受益。MySQL的用户账号: 用户名@...
    99+
    2022-10-18
  • MYSQL数据库管理之权限管理解读
    目录一、mysql权限简介1.MYSQL到底都有哪些权限呢?2.MYSQL的权限如何分布二、MYSQL权限经验原则三、MYSQL权限实战1.GRANT命令使用说明2.创建一个超级用户3.创建一个网站用户(程序用户)4.创...
    99+
    2023-03-20
    MYSQL数据库管理 MYSQL权限管理 MYSQL权限
  • Mongodb 用户权限管理及配置详解
    一、MongoDB命令 理解 admin 数据库 安装 MongoDB 时,会自动创建 admin 数据库,这是一个特殊数据库,提供了普通数据库没有的功能。 有些用户角色赋予用户操作多个数据库的权限,而这些角色只能在 a...
    99+
    2023-01-28
    Mongodb用户权限管理及配置详解 包括Mongodb访问控制配置 Mongodb开启权限验证 Mongodb账户创建 Mongodb账户管理命令
  • Mongodb用户权限管理及配置详解
    一、Mongodb命令 理解 admin 数据库 安装 MongoDB 时,会自动创建 admin 数据库,这是一个特殊数据库,提供了普通数据库没有的功能。 有些用户角色赋予用户操作...
    99+
    2023-01-28
    Mongodb 用户权限管理及配置详解 包括Mongodb访问控制配置 Mongodb开启权限验证 Mongodb账户创建 Mongodb账户管理命令
  • MySQL学习——管理用户权限
    MySQL学习——管理用户权限 摘要:本文主要学习了使用DCL语句管理用户权限的方法。 了解用户权限 什么是用户 用户,指的就是操作和使用MySQL数据库的人。使用MySQL数据库需要用户先通过用户名和密码进行连接,然后才能进行操作,不同的...
    99+
    2020-09-09
    MySQL学习——管理用户权限
  • Mysql 用户权限管理实现
    1. MySQL 权限介绍 mysql中存在4个控制权限的表,分别为user表,db表,tables_priv表,columns_priv表,我当前的版本mysql 5.7.22 。 mysql权限表的验证过程为: ...
    99+
    2022-05-25
    Mysql 用户权限管理
  • Mysql用户权限分配详解
    文章目录 MySQL 权限介绍一、Mysql权限级别分析(1)全局级别(1.1) USER表的组成结构(1.1.1) 用户列(1.1.2) 权限列(1.1.3) 安全列(1.1.4) 资源控制...
    99+
    2023-09-14
    mysql 数据库 java
  • MySQL中怎么实现用户账户管理和权限管理
    MySQL中怎么实现用户账户管理和权限管理,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。mysql 的权限体系大致分为5个层级:全局层级全局权...
    99+
    2022-10-18
  • mysql 用户及权限管理 小结
    转载自https://www.cnblogs.com/SQL888/p/5748824.html MySQL 默认有个root用户,但是这个用户权限太大,一般只在管...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作