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

标签 mysql ruby-on-rails ruby

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

相关文章:

java - 无法产生幻读

mysql - 从逗号分隔的单个字符串中查找不同的值

ruby-on-rails - 使用 Apache 运行 Mongrel for Rails

ruby-on-rails - 将 Kubernetes 与 ruby​​ on rails 应用程序一起使用

javascript - 序列化返回日期的时间错误

mysql - 在 MySQL 中向 UNION 添加条件

ruby-on-rails - Rails 模块名称首字母缩写

ruby-on-rails - 文本字段 : ERROR invalid body size 上的 Heroku Rails 日志错误消息

ruby-on-rails - 如何在 gmaps4rails 上配置其他属性?

ruby-on-rails - 通过 _type 字段实例化 mongoid 子类