`

[MySQL]查看用户权限与GRANT用法

阅读更多

 

查看用户权限

show grants for 你的用户

比如:
show grants for root@'localhost';

Grant 用法

 

 

 

GRANT USAGE ON *.* TO 'discuz'@'localhost' IDENTIFIED BY PASSWORD '*C242DDD213BE9C6F8DA28D49245BF69FC79A86EB';
GRANT ALL PRIVILEGES ON `discuz`.* TO 'discuz'@'localhost';

我先按我的理解解释一下上面两句的意思
建立一个只可以在本地登陆的 不能操作的用用户名 discuz 密码为 ***** 已经加密了的
然后第二句的意思是 ,给这个discuz用户操作discuz数据库的所有权限

使用GRANT

GRANT命令用来建立新用户,指定用户口令并增加用户权限。其格式如下:

mysql> GRANT <privileges> ON <what>
-> TO <user> [IDENTIFIED BY "<password>"]
-> [WITH GRANT OPTION];


  正如你看到的,在这个命令中有许多待填的内容。让我们逐一地对它们进行介绍,并最终给出一些例子以让你对它们的协同工作有一个了解。

  <privileges>是一个用逗号分隔的你想要赋予的权限的列表。你可以指定的权限可以分为三种类型:

  数据库/数据表/数据列权限: Alter: 修改已存在的数据表(例如增加/删除列)和索引。
Create: 建立新的数据库或数据表。
Delete: 删除表的记录。
Drop: 删除数据表或数据库。
INDEX: 建立或删除索引。
Insert: 增加表的记录。
Select: 显示/搜索表的记录。
Update: 修改表中已存在的记录。

  全局管理权限:

file: 在MySQL服务器上读写文件。
PROCESS: 显示或杀死属于其它用户的服务线程。
RELOAD: 重载访问控制表,刷新日志等。
SHUTDOWN: 关闭MySQL服务。

  特别的权限:

ALL: 允许做任何事(和root一样)。
USAGE: 只允许登录--其它什么也不允许做。


  这些权限所涉及到的MySQL的特征,其中的一些我们至今还没看到,而其中的绝大部分是你所熟悉的。

<what> 定义了这些权限所作用的区域。*.*意味着权限对所有数据库和数据表有效。dbName.*意味着对名为dbName的数据库中的所有数据表有效。 dbName.tblName意味着仅对名为dbName中的名为tblName的数据表有效。你甚至还可以通过在赋予的权限后面使用圆括号中的数据列的列表以指定权限仅对这些列有效(在后面我们将看到这样的例子)。

  <user>指定可以应用这些权限的用户。在MySQL中,一个用户通过它登录的用户名和用户使用的计算机的主机名/IP地址来指定。这两个值都可以使用%通配符(例如kevin@%将允许使用用户名kevin从任何机器上登录以享有你指定的权限)。

  <password>指定了用户连接MySQL服务所用的口令。它被用方括号括起,说明IDENTIFIED BY "<password>"在GRANT命令中是可选项。这里指定的口令会取代用户原来的密码。如果没有为一个新用户指定口令,当他进行连接时就不需要口令。

这个命令中可选的WITH GRANT OPTION部分指定了用户可以使用GRANT/REVOKE命令将他拥有的权限赋予其他用户。请小心使用这项功能--虽然这个问题可能不是那么明显!例如,两个都拥有这个功能的用户可能会相互共享他们的权限,这也许不是你当初想看到的。

  让我们来看两个例子。建立一个名为dbmanager的用户,他可以使用口令managedb从server.host.net连接 MySQL,并仅仅可以访问名为db的数据库的全部内容(并可以将此权限赋予其他用户),这可以使用下面的GRANT命令:

mysql> GRANT ALL ON db.*
-> TO dbmanager@server.host.net
-> IDENTIFIED BY "managedb"
-> WITH GRANT OPTION;


现在改变这个用户的口令为funkychicken,命令格式如下:
   mysql> GRANT USAGE ON *.*
   -> TO dbmanager@server.host.net
   -> IDENTIFIED BY "funkychicken";

请注意我们没有赋予任何另外的权限(the USAGE权限只能允许用户登录),但是用户已经存在的权限不会被改变。

  现在让我们建立一个新的名为jessica的用户,他可以从host.net域的任意机器连接到MySQL。他可以更新数据库中用户的姓名和 email地址,但是不需要查阅其它数据库的信息。也就是说他对db数据库具有只读的权限(例如,Select),但是他可以对Users表的name列和email列执行Update操作。命令如下:

mysql> GRANT Select ON db.*
-> TO jessica@%.host.net
-> IDENTIFIED BY "jessrules";
mysql> GRANT Update (name,email) ON db.Users
-> TO jessica@%.host.net;


  请注意在第一个命令中我们在指定Jessica可以用来连接的主机名时使用了%(通配符)符号。此外,我们也没有给他向其他用户传递他的权限的能力,因为我们在命令的最后没有带上WITH GRANT OPTION。第二个命令示范了如何通过在赋予的权限后面的圆括号中用逗号分隔的列的列表对特定的数据列赋予权限。

 

来自: http://hi.baidu.com/liheng%5F2009/blog/item/0f2aaebd30fc980719d81f9b.html

分享到:
评论

相关推荐

    mysql 赋给用户权限 grant all privileges on.docx

    本文将详细介绍 GRANT 语句的使用方法和参数说明。 GRANT 语句的基本格式为: `GRANT 权限1, 权限2, … 权限n ON 数据库名称. 表名称 TO 用户名@用户地址 IDENTIFIED BY ‘连接口令’;` 其中,权限1, 权限2, … ...

    mysql用户权限设置

    本文将详细介绍 MySQL 用户权限设置的相关知识点,包括创建用户、修改密码、赋予权限、回收权限、查看用户权限等。 一、创建用户 在 MySQL 中,可以使用 CREATE USER 语句创建新用户,例如: ```sql CREATE USER ...

    MySQL-Grant命令说明

    本文将深入探讨`GRANT`命令的使用方法,包括其基本语法、权限层级以及如何针对不同类型的用户进行权限分配。 #### `GRANT`命令基本语法 `GRANT`命令的基本格式如下: ``` GRANT privileges ON database.table TO ...

    开启外部访问mysql权限的功能

    "开启外部访问mysql权限的功能" ...开启外部访问mysql权限的功能需要安装mysql服务、配置防火墙、授权用户访问权限和解决中文乱码问题等多个步骤。只有正确地完成每个步骤,才能成功地开启外部访问mysql权限的功能。

    远程用户连接mysql授权

    在MySQL命令行中,可以使用`GRANT`语句来授予用户特定的权限。例如,若要允许用户从任意远程主机连接到MySQL服务器,并且拥有所有权限,可以执行以下命令: ```sql GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' ...

    在MySQL数据库增加新用户权限

    本文主要探讨了两种方法,即使用GRANT语句和直接操作MySQL授权表来完成这一过程,但推荐使用GRANT语句,因为这种方法更简洁且出错的可能性较小。 首先,我们来看如何使用GRANT语句来创建新用户并分配权限。GRANT...

    MYSQL权限不够解决办法

    ### MySQL权限不够解决办法 在使用MySQL数据库的过程中,可能会遇到“权限不足”的错误提示,这通常是因为当前用户没有足够的权限来执行某些操作(如创建表、删除数据等)。本文将详细介绍如何解决MySQL权限不足的...

    mysql 远程root权限

    - 使用`GRANT`语句授予`root`用户远程访问权限。 ```sql GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION; ``` 这条命令授予了`root`用户从任何主机(由`%`通配符表示)访问数据库的全部权限,并...

    mysql基础补充2-用户登录和权限问题

    MySQL 是一个功能强大且广泛使用的关系型数据库管理系统,它提供了丰富的用户登录和权限管理机制,确保数据库的安全性和可靠性。本文将详细介绍 MySQL 的用户登录和权限问题,以 MySQL 5.6 为例,帮助读者深入了解 ...

    更新MySql权限.zip

    通常,这会涉及修改MySQL配置文件(如my.ini或my.cnf),开放MySQL服务监听所有IP地址,以及在MySQL权限系统中为特定用户分配远程访问权限。 3. **mysqlorder_new.txt**:可能包含了新建MySQL用户的命令脚本,或者是...

    MySql\Mysql创建用户和表.docx

    本文详细介绍了 Mysql 创建用户和表的方法,包括使用 CREATE USER 语句、GRANT 语句和直接向 mysql.user 表插入记录三种方法,并提供了实例和详细的语法解释,以便读者更好地理解和掌握 Mysql 创建用户和表的知识。

    MySQL查询用户权限的方法总结

    首先,最直接查询用户权限的方法是使用MySQL的`SHOW GRANTS`命令。此命令可以直接显示指定用户的权限列表。例如,如果要查询名为`root`,连接地址为`localhost`的用户的所有权限,可以使用以下命令: ```sql SHOW ...

    MySQL恢复root用户超级权限方法.docx

    ### MySQL恢复root用户超级权限方法 #### 背景与问题描述 在使用MySQL数据库时,如果忘记了root用户的密码或由于某些原因导致root用户失去了超级权限(即管理员权限),那么将会给数据库管理带来极大的不便。本文...

    MySQL中创建用户及授权

    在 MySQL 中创建用户有两种方法:使用 CREATE USER 命令和使用 GRANT 命令。 使用 CREATE USER 命令 CREATE USER 命令用于创建新的 MySQL 账户。要使用 CREATE USER,您必须拥有 mysql 数据库的全局 CREATE USER ...

    MySQL-添加新用户简化说明

    每次使用`GRANT`命令分配权限后,都需要通过`FLUSH PRIVILEGES`命令来更新MySQL服务器内部的权限缓存,以确保新设置的权限立即生效。 ```sql FLUSH PRIVILEGES; ``` 如果省略此步骤,可能不会立即看到权限更改的...

    mysql开启远程连接权限

    接下来,我们使用GRANT语句为root用户授予所有数据库的所有权限。这里需要注意的是,`root@'%'`表示允许任何IP地址的主机访问root用户。 ```sql grant all privileges on *.* to root@'%' identified by '123456'; ...

    MySQL验证用户权限的方法

    在了解MySQL验证用户权限的方法之前,首先需要了解MySQL是如何确定用户身份的。MySQL通过两个字段——User和Host来确定用户的登录身份。在配置MySQL用户权限时,会根据Host和User字段的匹配程度来赋予用户不同的权限...

    MySQL:grant_语法详解(MySQL_5.X)

    MySQL数据库管理中,权限控制是确保数据库安全的重要组成...通过上述讲解,可以看到grant语句在MySQL权限管理中扮演了非常关键的角色。正确的使用grant语句不仅能够提升管理效率,而且能够增强系统的安全性和稳定性。

    MySQL远程登录权限设置

    #### 五、MySQL权限详细分类 MySQL中的权限可以根据其作用范围分为不同的类型: - **全局管理权限**:这类权限通常与MySQL服务器的整体管理相关。 - FILE:在MySQL服务器上读写文件。 - PROCESS:显示或杀死属于...

Global site tag (gtag.js) - Google Analytics