我刚刚在Ubuntu18.04上安装了MariaDB 10.1.29。在命令行中,我可以使用sudo连接:
sudo mysql -u root -p
但不能没有sudo。
此外,如果我尝试通过DBeaver连接到数据库,我会得到:
Could not connect: Access denied for user 'root'@'localhost'
凭据是正确的。我试着安装了MySQL 5.7,但我也遇到了完全相同的问题。
我遗漏了什么?
发布于 2018-06-04 02:21:22
事实证明,这是MariaDB和MySQL的预期行为。要解决此问题,建议创建一个单独的用户并授予对创建的所有数据库的访问权限。下面是关于如何使用命令行创建数据库并将权限授予您选择的用户的逐步指南。
登录MariaDB/MySQL
$ sudo mysql -u root -p
创建数据库
mysql> CREATE DATABASE `database_name`;
创建用户
mysql> CREATE USER 'user_name' IDENTIFIED BY 'a_secure_password';
授予用户权限
mysql> GRANT ALL PRIVILEGES ON database_name.* TO 'user_name'@'%' WITH GRANT OPTION;
应用更改
mysql> FLUSH PRIVILEGES;
https://stackoverflow.com/questions/50453078
复制相似问题