我正在尝试在我的计算机上启动并运行一个 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/