0

私はレガシーデータベースを扱っており、関連付けに関する Rails ガイドも読んでいます。

私は2つのモデルを持っています。diaryモデルとモデルanimal

日記.rb

class Diary < ActiveRecord::Base
  establish_connection :premvet

  attr_accessible :DiaryNo ,:DiaryName, :DiaryDate, :SlotHour, :TotalSlots, :BlockSlots, :BlockBooked, :FreeSlot, :BookedSlot

  self.table_name = 'diary'
  self.primary_key = 'DiaryNo'

  has_many :animals, :foreign_key => 'DiaryQueue'
end

動物.rb

class Animal < ActiveRecord::Base
  establish_connection :premvet

  self.table_name = 'animal'
  self.primary_key = 'PVID'

  attr_accessible :AddedBy, :Age, :AnimalBFAmount, :AnimalBalance, :AnimalName, :Archive, :BillType, :Breed, :ChronicStatus, :Class, :Classification, :ClientKey, :Colour, :Date1, :DateOfBirth, :DateofBirth, :Dead, :DiaryQueue, :DiscField, :DrugsAtCost, :DrugsNoVAT, :ESDAmount, :ESDType, :FNote, :FirstRegisteredDate, :Height, :IDNumber, :Insured, :InsuredWith, :IsClient, :IsClientDate, :IsMaster, :LastBilledAmount, :LastBilledDate, :LastConsDate, :LastContributionDate, :LastPaidDate, :LastWeightDate, :Locked, :LoyaltyMultiplier, :LoyaltyPoints, :MR_Flag_0, :MR_Flag_1, :MR_Flag_10, :MR_Flag_11, :MR_Flag_12, :MR_Flag_13, :MR_Flag_14, :MR_Flag_15, :MR_Flag_2, :MR_Flag_3, :MR_Flag_4, :MR_Flag_5, :MR_Flag_6, :MR_Flag_7, :MR_Flag_7, :MR_Flag_8, :MR_Flag_9, :Mileage, :Neutered, :NextApptDate, :ORT, :OldSex, :Opt_Flag_0, :Opt_Flag_1, :Opt_Flag_2, :Opt_Flag_3, :Opt_Flag_4, :Opt_Flag_5, :Opt_Flag_6, :Opt_Flag_7, :PVID, :PreferredContact, :PreferredUser, :Ref1, :RefPrac, :ReferredBy, :SSDType, :SeenInPeriod, :SendBill, :Sex, :SiteAnimal, :Species, :Status, :SurcAmount, :SurcType, :SurgeryNumber, :TBU, :TOSAmount, :TOSDrugs, :TOSFees, :TOSType, :Weight

  belongs_to :client, :foreign_key => 'ClientKey'
  belongs_to :diary, :foreign_key => 'DiaryNo'
end

動物のインデックス ビュー

<% @animals_todaysappointments.each do |animal| %>
  <tr>
    <td><%= animal.id %></td>    
    <td><%= animal.AnimalName %></td>
    <td><%= link_to animal.client.Surname, animal.client %></td>    
    <td><%= animal.Species %></td>
    <td><%= animal.Breed %></td>
    <td><%= animal.NextApptDate.strftime("%d %b. %Y -  %H:%M") %></td>        
    <td><%= animal.DiaryQueue %>
    <td><%= animal.diary.DiaryName %></td>    
    <td><%= link_to 'Show', animal %></td>
  </tr>
<% end %>

ご覧のとおり、以下を使用して animal テーブルから DiaryQueue を表示しています。

<td><%= animal.DiaryQueue %>

そして、私は日記テーブルから DiaryName を表示しようとしています:

<td><%= animal.diary.DiaryName %></td>    

これは例外エラーで失敗します:

undefined method `DiaryName' for nil:NilClass

メソッドは次の@animals_todaysappointmentsようになります。

def appointments
    @animals_todaysappointments = Animal.where('DATE(NextApptDate) = ?', Date.today).page(params[:page]).per_page(15).order('NextApptDate ASC')
    respond_to do |format|
      format.html # index.html.erb
    end
  end

私が追加した場合:

delegate :DiaryName, :to => :diary

動物モデルにすると、次のエラーが発生します。

Animal#DiaryName delegated to diary.DiaryName, but diary is nil: #

各動物レコードには 0 ~ 10 の DiaryQueue 値があり、ダイアリー テーブルにはいくつかの行があります。行の例は次のとおりです。

DiaryNo  DiaryName  DiaryDate  SlotHour  TotalSlots  BlockBooked  FreeSlot  BookedSlot
--------------------------------------------------------------------------------------
1        Morning    2012-07-16 9         18          0            0         18

DiaryNo が同じ行がありますが、DiaryName も同じです。これらの行で変更されるのは、DiaryDate、SlotHour、TotalSlots、BlockBooked、FreeSlot、および BookedSlot だけです。

エラーを回避するために、次をビューに追加しました。

<% unless animal.DiaryName.nil? %>
 <td><%= animal.DiaryName %></td>
<% else %>
 <td><%= animal.DiaryQueue %>
<% end %>  

しかし、私は例外を受け取ります:

Animal#DiaryName delegated to diary.DiaryName, but diary is nil: #

私は何を間違っていますか?

4

1 に答える 1

1

上記の回答を踏まえて、Animal の belongs_to メソッドを次のように変更する必要があるかもしれません。

belongs_to :diary, :foreign_key => "DiaryQueue", :primary_key => "DiaryNo"

Animal#DiaryNo現在の実装では、モデルはに対して一致しようとしDiary#DiaryNoますが、あなたが望んでいたのは に対して一致することAnimal#DiaryQueueですDiary#DiaryNo

于 2012-08-09T12:20:16.990 に答える