将 rake db:migrate 与 sinatra 和 activerecord 一起使用(不是 rails)

using rake db:migrate with sinatra and activerecord (not rails)

我正在将 rake 与 sinatra 和 activerecord 一起使用(不是 rails)。我有两个模型 类 - Admin(在 admin.rb)和 Bill(bill.rb)。我能够 运行 rake db:create_migrations 具有以下输出(但我看不到数据库中的任何表 - sqlite)。知道我可能做错了什么吗?

== 20150907135939 CreateAdmins: migrating ======================================
-- create_table(:admins)
   -> 0.0011s
== 20150907135939 CreateAdmins: migrated (0.0012s) =============================

== 20150907140840 CreateBills: migrating ======================================
-- create_table(:bills)
   -> 0.0005s
== 20150907140840 CreateBills: migrated (0.0006s) =============================

Rakefile

# Rakefile

require './app'
require 'sinatra'
require 'active_record'
require 'sinatra/activerecord/rake'

Gemfile

# Gemfile

source 'https://rubygems.org'


gem "sinatra"
gem "activerecord"
gem "sinatra-activerecord"
gem 'sinatra-flash'
gem 'sinatra-redirect-with-flash'
gem 'rake'
gem 'sqlite3'

=begin
group :development do
 gem 'sqlite3'
 gem "tux"
end

group :production do
 gem 'sqlite3'
end
=end

当我 运行 在 test.rb 文件中执行以下查询时,出现异常:

puts("type email address of admin")
admin_email = gets.chomp
find_admin = Admin.find_by(email:admin_email) # read
puts("admin retrieved with email: #{find_admin.email} and name: #{find_admin.name}")

异常:

test.rb:41:in `<main>': undefined method `email' for nil:NilClass (NoMethodError)

我返回的对象为零(我使用 find_admin.nil 检查过?)

首先,尝试 strip 输入电子邮件后的前导和尾随空格,如下所示:

admin_email = gets.chomp.strip
puts "admin_email: #{admin_email.inspect}"

然后,再次尝试您的脚本。它应该有效。

为了解释这里发生了什么,您的查询:

find_admin = Admin.find_by(email:admin_email)

使用提供的电子邮件找不到管理员记录。所以,它是一个 nil 对象,当你调用:find_admin.emailnil.email 然后你得到错误:

undefined method `email' for nil:NilClass (NoMethodError)

您需要确保您有管理员使用给定的电子邮件。为此,您可以先在 rails 控制台中创建一个,执行以下操作:

Admin.create!(email: 'testadmin@test.com')

然后,尝试通过输入 testadmin@test.com 来找到上述管理员。

如果数据库中存在具有给定电子邮件的管理员记录,它应该可以工作。