gpt4 book ai didi

Mysql2::Error: 用户 'test' @'localhost' 对数据库 'depot_test' 的访问被拒绝

转载 作者:IT王子 更新时间:2023-10-28 23:45:58 24 4
gpt4 key购买 nike

我在这里有点难过。我创建了一个数据库,使用 depot_production 数据库没有问题。但是,最近每当我运行 rake 测试时,我都会收到一堆错误,例如

# Running tests:

EEEEEEEE

Finished tests in 0.031499s, 253.9763 tests/s, 0.0000 assertions/s.

1) Error:
test_should_create_product(ProductsControllerTest):
Mysql2::Error: Access denied for user 'test'@'localhost' to database 'depot_test'

奇怪的是我认为我的 database.yml 文件很好。每次我运行 db:migrate 时,我都会得到一个空行返回给我。我还添加了一个用户测试,但我认为这只将它添加到我的开发数据库中。我有点认为我的测试、生产和数据库不存在......

development:
adapter: mysql2
encoding: utf8
reconnect: false
database: depot_development
pool: 5
username: root
password: admin
socket: /tmp/mysql.sock

# Warning: The database defined as "test" will be erased and
# re-generated from your development database when you run "rake".
# Do not set this db to the same as development or production.
test:
adapter: mysql2
encoding: utf8
reconnect: false
database: depot_test
pool: 5
username: test
password: testy
socket: /tmp/mysql.sock

production:
adapter: mysql2
encoding: utf8
reconnect: false
database: depot_production
pool: 5
username: prod
password: mypassword
socket: /tmp/mysql.sock

任何建议将不胜感激,谢谢。

感谢您在此陪伴我。我觉得我很接近,但有些奇怪。这就是我所做的。

 mysql> use depot_test;
ERROR 1049 (42000): Unknown database 'depot_test'
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| depot_development |
| development |
| mysql |
| performance_schema |
| test |
+--------------------+
6 rows in set (0.01 sec)

mysql> use depot_test
ERROR 1049 (42000): Unknown database 'depot_test'
mysql> use test
Database changed
mysql> GRANT SELECT, INSERT, DELETE ON `test` TO test@'localhost' IDENTIFIED BY 'testy';
ERROR 1146 (42S02): Table 'test.test' doesn't exist
mysql> GRANT SELECT, INSERT, DELETE ON `depot_test` TO test@'localhost' IDENTIFIED BY 'testy';
ERROR 1146 (42S02): Table 'test.depot_test' doesn't exist

最佳答案

因此,首先以 root 或从终端调用的任何您的 root 用户身份登录。

mysql -u root -p

CREATE DATABASE depot_test

CREATE USER 'test'@'localhost' IDENTIFIED BY 'mypass123';

USE depot_test

登录mysql后,授予用户test权限(记得修改密码)

GRANT ALL privileges on depot_test.* to test@localhost identified by 'mypass123';

FLUSH PRIVILEGES;

您需要在 database.yml 中将通行证更改为“mypass123”

关于Mysql2::Error: 用户 'test' @'localhost' 对数据库 'depot_test' 的访问被拒绝,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16003338/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com