Я пытаюсь установить некоторые продвинутые отношения в своих моделях RoR.
Пока я работаю над проектами и задачами. У проектов есть задачи, а у пользователей есть проекты.
Теперь я хочу, чтобы пользователь, который «зарегистрировался» в проекте, теперь мог «зарегистрироваться» для задач в этом проекте.
Кратко о моих текущих занятиях:
class AdminUser < ActiveRecord::Base
has_and_belongs_to_many :projects
has_and_belongs_to_many :tasks
has_many :admin_users_projects
[...]
class AdminUsersProject < ActiveRecord::Base
belongs_to :admin_user
has_and_belongs_to_many :project
has_many :tasks
[...]
class Project < ActiveRecord::Base
has_many :tasks
has_and_belongs_to_many :admin_users
has_and_belongs_to_many :admin_users_projects
[...]
class Task < ActiveRecord::Base
belongs_to :project
has_and_belongs_to_many :admin_users
belongs_to :admin_users_project
[...]
Схема выглядит так:
create_table "admin_users", :force => true do |t|
t.string "first_name", :limit => 25
t.string "last_name", :limit => 50
t.string "email", :limit => 100, :default => "", :null => false
t.string "hashed_password", :limit => 40
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
t.string "username", :limit => 25
t.string "salt", :limit => 40
end
add_index "admin_users", ["username"], :name => "index_admin_users_on_username"
create_table "admin_users_projects", :force => true do |t|
t.integer "admin_user_id"
t.integer "project_id"
end
add_index "admin_users_projects", ["admin_user_id", "project_id"], :name => "index_admin_users_projects_on_admin_user_id_and_project_id"
create_table "projects", :force => true do |t|
t.string "name"
t.integer "position"
t.boolean "visible", :default => false
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
end
create_table "tasks", :force => true do |t|
t.integer "project_id"
t.string "permalink"
t.integer "position"
t.boolean "visible"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
t.string "name"
t.integer "admin_user_id"
t.integer "progress"
end
add_index "tasks", ["permalink"], :name => "index_tasks_on_permalink"
add_index "tasks", ["project_id"], :name => "index_tasks_on_project_id"
end
У меня есть представление, которое показывает проекты, а затем представление их подмножества задач. У меня также есть представление, которое показывает проекты пользователей, но теперь я хочу, чтобы оно показывало подмножество задач пользователей.
Моя точка зрения на «admin_user_projects» вкратце такова:
<% @admin_users_projects.each do |admin_users_projects| %>
<tr>
<td><%= admin_users_projects.admin_user_id %></td>
<td><%= admin_users_projects.admin_user.username %></td>
<td><%= admin_users_projects.project_id %></td>
<td><%= admin_users_projects.project.name %></td>
</tr>
<% end %>
Это показывает идентификатор пользователя, имя пользователя, идентификатор проекта и имя проекта. Теперь я хочу добавить строку, показывающую, на сколько задач пользователь «зарегистрирован» для этого проекта. я пытался
<td><%= admin_users_projects.tasks.size %></td>
Но получите следующее:
Mysql2::Error: Unknown column 'tasks.admin_users_project_id' in 'where clause': SELECT COUNT(*) FROM `tasks` WHERE `tasks`.`admin_users_project_id` = 1
У кого-нибудь есть идеи, как заставить эти отношения работать эффективно?