发表于 2024-12-4 15:50:17

如何从命令行管理MySQL数据库和用户

MySQL是最流行的开源关系数据库之一。

MySQL服务器允许我们创建大量用户和数据库并授予适当的权限,以便用户可以访问和管理数据库。

本教程向我们展示如何通过命令行创建MySQL和MariaDB数据库和用户,通过该教程你将学会这些。

前提条件

在开始本教程之前,我们假设你在自己的系统上已经安装了MySQL或MariaDB服务软件。所有命令都将作为root用户在MySQL提示符内执行。

在命令行终端中键入如下命令进入root帐号的MySQL的命令行交互对话。

mysql -u root -p
创建一个MySQL数据库

要创建新的MySQL或MariaDB数据库,运行以下命令,只需将database_name替换为您要创建的数据库的名称:

CREATE DATABASE database_name;
输出:

Query OK, 1 row affected (0.00 sec)
如果你创建的数据库已经存在,你将会看到输出如下错误提示信息:

ERROR 1007 (HY000): Can't create database 'database_name'; database exists
为了避免创建一个已经存在的同名数据库时产生错误,我们可以通过以下命令来避免。

CREATE DATABASE IF NOT EXISTS database_name;
输出:

Query OK, 1 row affected, 1 warning (0.00 sec)
在上面的输出中你将会看到 Query OK 这意味着SQL语句执行成功,而其中的1 warning告诉我们创建的数据库已经存在被创建过。

列出所有MySQL数据库

我们可以通过以下命令列出所有在我们MySQL或MariaDB中的数据库。

SHOW DATABASES;
输出:

+--------------------+
| Database         |
+--------------------+
| information_schema |
| database_name      |
| mysql            |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.00 sec)

information_schema,mysql,performance_schema和sys数据库是在安装时创建的,它们存储有关所有其他数据库,系统配置,用户,权限和其他重要数据的信息。 这些数据库是MySQL安装的正确功能所必需的。


删除MySQL数据库

要删除MySQL或MariaDB,数据库运行以下命令:

DROP DATABASE database_name;
输出:

Query OK, 0 rows affected (0.00 sec)
假如你删除的数据库不存在,你将会看到如下的输出信息:

ERROR 1008 (HY000): Can't drop database 'database_name'; database doesn't exist
我们可以使用如下命令避免这个错误:

DROP DATABASE IF EXISTS database_name;
输出:

Query OK, 0 rows affected, 1 warning (0.00 sec)
通过上面的输出,你可以看到 Query OK 这就意味着我们执行成功,而其中的1 warning则告诉我们数据库database_name已经存在。

创建MySQL用户

MySQL中的用户帐户由用户名和主机名部分组成。

要创建新的MySQL或MariaDB用户帐户,请运行以下命令,只需将“database_user”替换为您要创建的用户的名称:

CREATE USER 'database_user'@'localhost' IDENTIFIED BY 'user_password';
在上面的命令中,我们将主机名部分设置为localhost,这意味着该用户只能从localhost(即运行MySQL Server的系统)连接到MySQL服务器。 如果要授予其他主机的访问权限,只需使用远程计算机IP更改localhost,或使用'%'通配符作为主机部分,这意味着用户帐户将能够从任何主机进行连接。

与使用数据库时相同,以避免在尝试创建已存在的用户帐户时出错,您可以使用:

CREATE USER IF NOT EXISTS 'database_user'@'localhost' IDENTIFIED BY 'user_password';
输出:

Query OK, 0 rows affected, 1 warning (0.00 sec)
更改MySQL用户帐户密码

更改MySQL或MariaDB用户帐户密码的语法取决于您在系统上运行的服务器版本。

您可以通过发出以下命令找到您的服务器版本:

mysql --version
如果你有MySQL 5.7.6及更新版或MariaDB 10.1.20及更新版,要更改密码,请使用以下命令:

ALTER USER 'database_user'@'localhost' IDENTIFIED BY 'new_password';
如果你有MySQL 5.7.5及更早版本或MariaDB 10.1.20及更早版本,那么使用:

SET PASSWORD FOR 'database_user'@'localhost' = PASSWORD('new_password');
在这两种情况下,输出应如下所示:

Query OK, 0 rows affected (0.00 sec)
列出所有MySQL帐号

我们可以通过查询mysql.users表列出所有MySQL或MariaDB用户帐户:

SELECT user, host FROM mysql.user;
输出应类似于下面的内容。 此输出列出了在Ubuntu计算机上运行的MySQL 5.7服务器的默认用户以及我们之前添加的另外两个用户帐户,“database_user”@“%”和“database_user”@“localhost”。
输出:

+------------------+-----------+
| user             | host      |
+------------------+-----------+
| database_user    | %         |
| database_user    | localhost |
| debian-sys-maint | localhost |
| mysql.session    | localhost |
| mysql.sys      | localhost |
| root             | localhost |
+------------------+-----------+
6 rows in set (0.00 sec)

删除MySQL帐号

要删除用户帐户,请使用以下命令:

DROP USER 'database_user@'localhost';
如果您尝试删除不存在的用户帐户,则会发生错误。

ERROR 1396 (HY000): Operation DROP USER failed for 'database_user'@'localhost'
与使用数据库时相同,以避免您可以使用的错误:

DROP USER IF EXISTS 'database_user'@'localhost';
输出:

Query OK, 0 rows affected, 1 warning (0.00 sec)
授予MySQL用户帐户权限

可以为用户帐户授予多种类型的权限。 您可以在此处找到MySQL支持的完整权限列表。 在本指南中,我们将通过几个例子:

要通过特定数据库授予用户帐户的所有权限,请使用以下命令:

GRANT ALL PRIVILEGES ON database_name.* TO 'database_user'@'localhost';
要为所有数据库上的用户帐户授予所有权限,请使用以下命令:

GRANT ALL PRIVILEGES ON *.* TO 'database_user'@'localhost';
要从数据库中对特定表上的用户帐户授予所有权限,请使用以下命令:

GRANT ALL PRIVILEGES ON database_name.table_name TO 'database_user'@'localhost';
如果您只想通过特定数据库类型为用户帐户授予特定权限:

GRANT SELECT, INSERT, DELETE ON database_name.* TO database_user@'localhost';
撤消MySQL用户帐户的权限

如果您需要从用户帐户撤消一个或多个权限或所有权限,则语法几乎与授予权限相同。 例如,如果要通过特定数据库撤消用户帐户的所有权限,请使用以下命令:

REVOKE ALL PRIVILEGES ON database_name.* TO 'database_user'@'localhost';
显示MySQL用户帐户权限

要查找授予特定MySQL用户帐户类型的权限,请执行以下操作:

SHOW GRANTS FOR 'database_user'@'localhost';
输出:

+---------------------------------------------------------------------------+
| Grants for database_user@localhost                                        |
+---------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO 'database_user'@'localhost'                         |
| GRANT ALL PRIVILEGES ON `database_name`.* TO 'database_user'@'localhost'|
+---------------------------------------------------------------------------+
2 rows in set (0.00 sec)

总结

本教程仅介绍基础知识,但对于想要学习如何从命令行管理MySQL数据库和用户的人来说,它应该是一个很好的开端。 您还可以查看有关如何重置MySQL root密码的教程,以防您忘记密码。


原文链接:https://linux265.com/news/3591.html

页: [1]
查看完整版本: 如何从命令行管理MySQL数据库和用户