在 Sinatra 中使用 ActiveRecord 时 rake db:migrate 不工作

rake db:migrate not working when using ActiveRecord with Sinatra

我正在尝试创建一个非常基本的 Sinatra 应用程序,它仅使用 Active Record 和 Sqlite3。

为了尽可能完整,我按照教程中的说明进行操作,该教程按顺序说明了以下步骤:

  1. 通过将以下代码放入主应用程序文件来创建数据库:
ActiveRecord::Base.establish_connection(
  :adapter =>'sqlite3',
  :database=>'wiki.db'
)

class User < ActiveRecord::Base
  validates :username, presence: true, uniqueness: true
  validates :password, presence: true
end

  1. 要创建数据库并更改其结构,请创建一个包含以下内容的 Rakefile:
require "./wadapp.rb"                                                                                    
require "sinatra/activerecord/rake"
  1. 保存 Rake 文件并运行在终端中输入以下命令:
rake db:create_migration NAME=create_users
  1. 将在 db/migrate/ 中创建一个名为 timestamp_create_users.rb 的新文件导航到该文件并使用以下内容进行编辑:
class CreateUsers < ActiveRecord::Migration[6.0]                                                         
  def change
    create_table :users do |t| 
      t.string :username
      t.string :password
      t.boolean :edit
      t.timestamps null: false
    end 
    User.create(username: "Admin", password: "admin", edit: true)
  end 
end
  1. 在终端 运行 命令 rake db:migrate.

这是代码停止工作的最后一点。我没有任何输出表明 :users 已创建,并且在应用程序中无法访问 table。

我试过回滚等,但没有迹象表明甚至创建了 table,所以没有任何回滚或改变?我也按照一些帖子的建议首先尝试 运行ning rake db:create 但出现以下错误:

(in /Users/jonathonday/ruby/wad/wiki)
rake aborted!
ActiveRecord::AdapterNotSpecified: The `development` database is not configured for the `default_env` environment.

Available databases configurations are:


/Users/jonathonday/.rvm/gems/ruby-2.6.3/gems/activerecord-6.0.2.1/lib/active_record/connection_adapters/connection_specification.rb:251:in `resolve_symbol_connection'
/Users/jonathonday/.rvm/gems/ruby-2.6.3/gems/activerecord-6.0.2.1/lib/active_record/connection_adapters/connection_specification.rb:219:in `resolve_connection'
/Users/jonathonday/.rvm/gems/ruby-2.6.3/gems/activerecord-6.0.2.1/lib/active_record/connection_adapters/connection_specification.rb:140:in `resolve'
/Users/jonathonday/.rvm/gems/ruby-2.6.3/gems/activerecord-6.0.2.1/lib/active_record/connection_handling.rb:187:in `resolve_config_for_connection'
/Users/jonathonday/.rvm/gems/ruby-2.6.3/gems/activerecord-6.0.2.1/lib/active_record/connection_handling.rb:50:in `establish_connection'
/Users/jonathonday/.rvm/gems/ruby-2.6.3/gems/activerecord-6.0.2.1/lib/active_record/tasks/database_tasks.rb:187:in `create_current'
/Users/jonathonday/.rvm/gems/ruby-2.6.3/gems/activerecord-6.0.2.1/lib/active_record/railties/databases.rake:39:in `block (2 levels) in <top (required)>'
Tasks: TOP => db:create
(See full trace by running task with --trace)

我也有 运行 命令 rake db:migrate 作为 root 用户 (sudo su) 并且确实得到了不同的错误:

(in /Users/jonathonday/ruby/wad/wiki)
rake aborted!
LoadError: cannot load such file -- sinatra
/Users/jonathonday/.rvm/rubies/ruby-2.6.3/lib/ruby/site_ruby/2.6.0/rubygems/core_ext/kernel_require.rb:54:in `require'
/Users/jonathonday/.rvm/rubies/ruby-2.6.3/lib/ruby/site_ruby/2.6.0/rubygems/core_ext/kernel_require.rb:54:in `require'

这是我在使用 ActiveRecord 创建和构建基本数据库时得到的指令,所以如果有任何遗漏或有更好的方法,我将非常乐意倾听。

我通过卸载 ActiveRecord 6.0.2.1 并安装版本 5.2.4 设法解决了这个问题。

这似乎解决了所有问题,当我现在 运行 rake db:migrate 我得到结果:

(in /Users/jonathonday/ruby/wad/wiki)
== 20200209194032 CreateUsers: migrating ======================================
-- create_table(:users)
   -> 0.0008s
== 20200209194032 CreateUsers: migrated (0.0178s) =============================

我不确定这是为什么,但我会 post 对此提出一个单独的问题。

我遇到了同样的问题,我相信我找到了你第二个问题的答案,为什么你必须恢复到旧版本的 Active Record(5.2 而不是 6.0)。

如果您查看 sinatra-activerecord repo,它们似乎已弃用 ActiveRecord::Base.establish_connection() 并用 set :database{}.

因此,如果您更改代码:

ActiveRecord::Base.establish_connection(:adapter =>'sqlite3', :database=>'wiki.db')

set :database, {:adapter =>'sqlite3', :database=>'wiki.db'}

您的代码无需使用旧版本的 Active Record 即可运行。至少对我有用。