执行rake db:migrate时的两个错误

来源:互联网 发布:vscode前端插件 编辑:程序博客网 时间:2024/05/18 01:54

        rails的确是来的方便,一个rails generate scaffold命令下来就可以生成view、controller和model的所有文件,然后再执行rake db:migrate就可以生成相应的数据库表结构。而就是这个简单的rake db:migrate却产生了预想不到的问题:

         首先交代一下背景:rails创建项目时,默认使用了SQLite数据库。为了快速上手,我换成了MySQL,也修改了相应的配置文件config/database.yml。

         第一个问题

                 rake aborted!

                 uninitialized constant Rake:DSL

        原因:默认安装的rake版本过低,不兼容

        解决办法:升级rake

        步骤:1. 安装0.9.2版本的rake,gem install rake -version=0.9.2

                     2. 卸载原来版本(可以通过gem -list rake查看当前安装的版本), gem uninstall rake -version=0.8.7

                     3. 更新所有组件,bundle update

         4.运行 rake db:migrate。于是出现第二个问题。


   第二个问题

         rake aborted!

         Mysql::Error: query: not connected: SHOW TABLES

   原因:MySQL5.1自带的libmySQL.dll和当前的rails不兼容

   解决办法:使用旧版本替换。

   步骤:1. 下载旧版本的libmySQL.dll: http://instantrails.rubyforge.org/svn/trunk/InstantRails-win/InstantRails/mysql/bin/libmySQL.dll

        2. 将下载的文件放到%RUBY_HOME/bin目录下。

 

   参考:

   http://stackoverflow.com/questions/6085610/rails-rake-problems-uninitialized-constant-rakedsl

       http://rordiary.com/blog/tag/mysql/

   

    

原创粉丝点击