我正在尝试理解Rails 3中的新arel引擎,我有一个问题。
我有两个模型,用户和任务
class User < ActiveRecord::Base
has_many :tasks
end
class Task < ActiveRecord::Base
belongs_to :user
end
这是我暗示关系的路线:
resources :users do
resources :tasks
end
这是我的任务控制器:
class TasksController < ApplicationController
before_filter :load_user
def new
@task = @user.tasks.new
end
private
def load_user
@user = User.where(:id => params[:user_id])
end
end
问题是,当我尝试调用新操作时出现以下错误:
NoMethodError: undefined method `tasks' for #<ActiveRecord::Relation:0x3dc2488>
我确信我的问题在于新的引擎引擎,有人知道我做错了什么吗?
对不起伙计们,这是我的schema.db文件:
ActiveRecord::Schema.define(:version => 20100525021007) do
create_table "tasks", :force => true do |t|
t.string "name"
t.integer "estimated_time"
t.datetime "created_at"
t.datetime "updated_at"
t.integer "user_id"
end
create_table "users", :force => true do |t|
t.string "email", :default => "", :null => false
t.string "encrypted_password", :limit => 128, :default => "", :null => false
t.string "password_salt", :default => "", :null => false
t.string "reset_password_token"
t.string "remember_token"
t.datetime "remember_created_at"
t.integer "sign_in_count", :default => 0
t.datetime "current_sign_in_at"
t.datetime "last_sign_in_at"
t.string "current_sign_in_ip"
t.string "last_sign_in_ip"
t.datetime "created_at"
t.datetime "updated_at"
t.string "username"
end
add_index "users", ["email"], :name => "index_users_on_email", :unique => true
add_index "users", ["reset_password_token"], :name => "index_users_on_reset_password_token", :unique => true
add_index "users", ["username"], :name => "index_users_on_username", :unique => true
end
答案 0 :(得分:2)
我相信你想要:
def load_user
@user = User.where(:id => params[:user_id]).first
end
在你要求记录之前,它会保持关系。
但find(params[:user_id])
仍然有效并返回记录。
答案 1 :(得分:1)
如果您更改load_user
方法,它是否有效?
def load_user
@user = User.find(params[:user_id])
end
此外,我认为您可能需要将new
操作更改为:
def new
@task = @user.tasks.build
end
答案 2 :(得分:0)
不要将Arel gem的界面与新的ActiveRecord查询界面混淆。此处描述的语法不起作用:http://github.com/brynary/arel
ActiveRecord使用Arel,但创建了自己的类似Arel的API。以下是新的ActiveRecord查询界面的简要介绍:http://m.onkey.org/2010/1/22/active-record-query-interface
答案 3 :(得分:0)
实际上非常简单。这是一种方法......
def new
@task = @user.tasks.new
end
private
def load_user
# you must call a non-deferred operator to actually return
# the tuple that is connected to your tasks
@user = User.where(:id => params[:user_id]).first
end
请务必查看我在Active Relation上进行的七部分学习系列。第一集将帮助您更清楚地了解您的错误。 http://Innovative-Studios.com/#pilot
find()在某些情况下不会弃用,如前所述。我会限制使用find()作为原子值(你在哪里搜索一个特定的项目/索引)任何可能是基于集合的东西我会坚持使用ActiveRecord中的Where(限制)子句包装器为Arel。