Я работаю над созданием основы того, что в конечном итоге станет административной панелью управления. Одна из вещей, которую в конечном итоге должна будет сделать панель управления, - это позволить пользователям искать пользователей игры и просматривать информацию о них. Информация о них находится в другой таблице, поэтому, естественно, мне приходилось нанимать ассоциации. Сейчас я просто пытаюсь настроить индекс, чтобы я знал, как работают ассоциации, прежде чем приступить к поиску и запуску.
Я пытаюсь объединить таблицу, называемую пользователями, с таблицей, называемой ставками, через таблицу с именем bets_users. У меня есть представление модели, контроллера и индекса, работающее для ставок, однако, когда я пытаюсь объединить модель ставок с моделью пользователей, я получаю NoMethodError в индексе Bets #.
Модель ставки:
class Bet < ActiveRecord::Base
has_many :bets_bet_odds
has_many :bet_odds, :through => :bets_bet_odds
has_many :bets_users
has_many :users, :through => :bets_users
def self.index_bets
find(:all, :joins => :users, :include => [:bets_users, :users])
end
end
Модель BetsUser
class BetsUser < ActiveRecord::Base
belongs_to :bet
belongs_to :user
end
Модель пользователя:
class User < ActiveRecord::Base
has_many :bets_users
has_many :bets, :through => :bets_users
end
Контролер ставок
class BetsController < ApplicationController
def index
@index_bets = Bet.index_bets
end
def edit
@bet = Bet.find(params[:id])
end
def update
@bet = Bet.find(params[:id])
if @bet.update_attributes(params[:bet])
redirect_to :controller => "bets", :action => "index"
end
end
end
Просмотр индекса ставок
<h1>Bets#index</h1>
<p>Find me in app/views/bets/index.html.erb</p>
<table border = "1">
<tr>
<th>id</th>
<th>user</th>
<th>scored</th>
<th>updated_at</th>
</tr>
<% @index_bets.each do |bet| %>
<tr>
<td><%= link_to h(bet.id), :controller => "bets",
:action => "edit",
:id => bet.id %>
</td>
<td><%=h bet.users.displayname %></td>
<td><%=h bet.scored %></td>
<td><%=h bet.updated_at %></td>
</tr>
<% end %>
</table>
Поле, которое я пытаюсь отобразить в дополнение к данным из таблицы ставок, - users.displayname. Когда я меняю отображаемое имя на id, я больше не получаю сообщение об ошибке, однако отображаемый идентификатор не является данными ни из одной из таблиц. Это длинное целое число длиной около 7 цифр.
Вот ошибка: отображение app / views / bets / index.html.erb, где поднята строка # 18: неопределенный метод `displayname 'для #
Вот sql из моего файла журнала:
Processing BetsController#index (for 127.0.0.1 at 2010-01-24 14:48:22) [GET]
Bet Load (4600.9ms)
SELECT `bets`.* FROM `bets` INNER JOIN `bets_users` ON (`bets`.`id` = `bets_users`.`bet_id`) INNER JOIN `users` ON (`users`.`id` = `bets_users`.`user_id`)
Bet Columns (97.4ms) SHOW FIELDS FROM `bets`
BetsUser Load (423.6ms) SELECT `bets_users`.* FROM `bets_users` WHERE (`bets_users`.bet_id IN (3,4,5,12,13,14,15,16,17,18,19,21,24,25,27,28,29,31,33,34,35,42,43,44,45,50,51,52,54,61,70,71,72,73,74,76,77,80,81,82,87,92,93,94,95,96,97,98,100,101,102,103,110,112,113,114,116,120,121,122,123,125,127,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,148,149,151,152,153,154,155,156,157,158,159,160,161,162,163,164,166,167,168,169,170,171,172,173,174,178,179,180,181,182,183,186,187,188,189,190,191,192,193,196,197,198,199,200,201,202,203,204,205,206,207,211,212,213,214,215,216,220,221,222,223,224,225,226,227,228,229,230,231,232,233,234,288,289,290,291,292,293,294,295,296,297,298,299,300,301,302,303,306,307,308,309,310,311,312,313,314,315,316,317,318,319,320,321,324,325,326,327,328,329,330,331,332,333,334,335,336,337,338,339,340,341,342,343,344,345,384,403,410,411,412,417,431,432,433,439,440,441,466,470,471,472,473,474,475,479,480,481,482,483,484,487,488,489,490,491,492,493,494,495,496,497,498,499,500,501,502,503,504,505,506,515,516,517,518,519,520,521,522,523,524,525,526,527,528,529,530))
BetsUser Columns (95.6ms) SHOW FIELDS FROM `bets_users`
User Columns (1063.6ms) SHOW FIELDS FROM `users`
User Load (7109.4ms) SELECT * FROM `users` WHERE (`users`.`id` IN (726,1,2,4))