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

我使用的是MySQL 5.4.1版本。


当前回答

SELECT * FROM mysql.user;

这是一个很大的表,所以您可能希望在选择的字段上更有选择性。

其他回答

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

use mysql;
select User from mysql.user;

这应该能达到你的目的。

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

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

db表在确定用户权限方面可能更为重要。我认为,如果您在GRANT命令中提到一个表,就会创建其中的一个条目。在我的情况下,mysql。用户表显示一个用户没有权限,明明可以连接和选择,等等。

mysql> select * from mysql.db;
mysql> select * from db;
+---------------+-----------------+--------+-------------+-------------+-------------+--------
| Host          | Db              | User   | Select_priv | Insert_priv | Update_priv | Del...
SELECT User FROM mysql.user;

使用上面的查询来获取MySQL用户。

要看到你的用户,就要使用mysql数据库。

USE mysql;

然后进行选择。

SELECT user,host FROM user;

另一种选择是放置BD.Table。

例如:

SELECT user,host FROM mysql.user;