我正在使用MySQL命令行实用程序,可以在数据库中导航。现在我需要查看用户帐户列表。我该怎么做呢?

我使用的是MySQL 5.4.1版本。


当前回答

我发现他的一个更有用,因为它提供了关于DML和DDL特权的额外信息

SELECT user, Select_priv, Insert_priv , Update_priv, Delete_priv, 
       Create_priv, Drop_priv, Shutdown_priv, Create_user_priv 
FROM mysql.user;

其他回答

使用这个查询:

SELECT User FROM mysql.user;

它将输出一个这样的表:

+-------+
| User  |
+-------+
| root  |
+-------+
| user2 |
+-------+

正如Matthew Scharley在关于这个答案的评论中指出的那样,如果您只想看到唯一的用户名,您可以根据User列进行分组。

这将显示唯一用户的列表:

SELECT DISTINCT User FROM mysql.user;
$>  mysql -u root -p -e 'Select user from mysql.user' > allUsersOnDatabase.txt

在Linux命令行提示符上执行此命令将首先询问MySQL root用户的密码。在提供正确的密码时,它将把所有数据库用户打印到文本文件中。

MySQL将用户信息存储在自己的数据库中。数据库名称为“MySQL”。在这个数据库中,用户信息在一个名为user的数据集中的表中。如果你想查看MySQL用户表中设置了哪些用户,运行以下命令:

SELECT User, Host FROM mysql.user;

+------------------+-----------+
| User             | Host      |
+------------------+-----------+
| root             | localhost |
| root             | demohost  |
| root             | 127.0.0.1 |
| debian-sys-maint | localhost |
|                  | %         |
+------------------+-----------+

Peter和Jesse是正确的,但是要确保您首先选择了“mysql”数据库。

use mysql;
select User from mysql.user;

这应该能达到你的目的。