"utf8", "username"= >"root", "adapter"= >"mysql"-6ren"> "utf8", "username"= >"root", "adapter"= >"mysql"-我正在尝试在我的计算机上启动并运行一个 Rails 应用程序,但我在创建数据库时遇到了问题。我已经正确安装/设置 rails、mysql 并安装了 mysql 2.8.1 gem(我用 gem lis-6ren">
gpt4 book ai didi

mysql - 无法 rake 分贝 :create:all -- Couldn't create database for {"encoding"= >"utf8", "username"= >"root", "adapter"= >"mysql"

转载 作者:可可西里 更新时间:2023-11-01 06:37:15 26 4
gpt4 key购买 nike

我正在尝试在我的计算机上启动并运行一个 Rails 应用程序,但我在创建数据库时遇到了问题。我已经正确安装/设置 rails、mysql 并安装了 mysql 2.8.1 gem(我用 gem list 验证了这一点)。

现在,我正在尝试运行“rake db:create:all”,但出现以下错误:

Couldn't create database for {"encoding"=>"utf8", "username"=>"root", "adapter"=>"mysql", "database"=>"pyo", "host"=>"localhost", "password"=>nil, "socket"=>"/tmp/mysql.sock"}, charset: utf8, collation: utf8_unicode_ci (if you set the charset manually, make sure you have a matching collation)

Couldn't create database for {"encoding"=>"utf8", "username"=>"root", "adapter"=>"mysql", "database"=>"pyo_test", "host"=>"localhost", "password"=>nil, "socket"=>"/tmp/mysql.sock"}, charset: utf8, collation: utf8_unicode_ci (if you set the charset manually, make sure you have a matching collation)

我目前在 Snow Leopard (10.6.6) 上运行 5.5.10 MySQL Community Server (GPL)

这是我的 database.yml 文件中的内容

development:
adapter: mysql
encoding: utf8
database: pyo
username: root
password:
socket: /tmp/mysql.sock
host: localhost

test:
adapter: mysql
encoding: utf8
database: pyo_test
username: root
password:
socket: /tmp/mysql.sock
host: localhost

我注意到错误的结尾是这样写的:“字符集:utf8,排序规则:utf8_unicode_ci(如果您手动设置字符集,请确保您有匹配的排序规则)”——这是问题所在吗?如果是这样,我该如何解决?

我已经在这件事上停留了几个小时,在 Google 上找不到任何有用的东西。因此,我们将不胜感激。

谢谢!!

最佳答案

我知道这个帖子已经过时了,但作为一个相信将良好可靠的文档保存在一个地方的 IT 人员来说:

问题实际上源于您的“config/database.yml”文件。您将 ROR 指向 MySQL 套接字的错误位置。

我遇到了这个问题,结果是 gem 是在 mac 系统上构建的,开发人员没有考虑其他操作系统,将他的“mysql.sock”文件放在“/tmp”目录中而不是“/var/run/mysqld/mysqld.sock”。

所以他的“database.yml”文件看起来像:

开发:
适配器:mysql2
#编码:utf8
数据库:一些数据库
游泳池:5
用户名:某个用户名
密码:一些密码
套接字:/tmp/mysql.sock

因为我使用的是 Ubuntu 系统,所以我必须将我的更改为以下内容:

开发:
适配器:mysql2
#编码:utf8
数据库:一些数据库
游泳池:5
用户名:某个用户名
密码:一些密码
套接字:/var/run/mysqld/mysqld.sock

是的,该错误可能会产生误导,但它与您的“编码”无关,也与您使用的是 localhost 还是 127.0.0.1 无关(至少在 linux/UNIX 系统中,这些翻译成相同的东西并且是同义词)

开始编辑

另外像我上面那样把encoding注释掉也是不好的所以我在这里提供修改以供引用。

开发:
适配器:mysql2
编码:utf8
数据库:一些数据库
游泳池:5
用户名:某个用户名
密码:一些密码
套接字:/var/run/mysqld/mysqld.sock

结束编辑

关于mysql - 无法 rake 分贝 :create:all -- Couldn't create database for {"encoding"= >"utf8", "username"= >"root", "adapter"= >"mysql",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5575876/

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