質問

いユーザーモデルの属性の初めての'および'last' したがって、たとえば、 ユーザーです。ます。初#=>"チャーリー" ユーザーです。ます。昨#=>"茶色"

このユーザーのモデルもvirtual属性'full_name'

#user.rb
def full_name
  [first,last].join(' ')
end

def full_name=(name) #don't know what to do with people w/ middle names
  split = name.split(' ')
  self.first = split[0]
  self.last = split[1]
end

したがって、たとえば、:

User.first.full_name = "Charlie Brown" #=> "Charlie Brown"
User.first.full_name = "Homer Simpson" #=> "Home Simpson"
User.first.save
User.first.first #=> "Homer"
User.first.last #=> "Simpson"

思いますできれば検索する仮想属性 したがって、たとえば、動的見:

User.find_by_full_name('Home Simpson') # this doesn't work

例条件アプリケーションを起動させ:

User.all(:conditions => ['full_name LIKE ?', query]) #this doesn't work

できないかと考えていかなSQL言語のできること;があれば、動的な仮想属性の探しも、余分なバニラのソースのstrudel.(誰でもここの冬には?)

また、懸念される名前を検索し、例えば、"ホームズ"が検索されるので初めてのカラムがないの'最後の"取得、例えば、 User.first.full_name #=> "Sherlock Holmes".

いったい、より包括的な検索:

ユーザーです。rb

def self.find_by_full_name(name) #returns an array of User model
  return all if name.blank?

  split = name.split(' ', 2)
  output = []
  if split.length > 1
    with_scope( :find => { :conditions => ['first LIKE ?', "%#{split[0]}%"] }) do
      output << all(:conditions => ['last LIKE ?', "%#{split[1]}%"])
      output.flatten!
    end
  elsif split.length == 1
    output << all(:conditions => ['first LIKE ?', "%#{split[0]}%"])
    output << all(:conditions => ['last LIKE ?', "%#{split[0]}%"])
    output.flatten!
  end
end

例えば、

User.find_by_full_name("John").map(&:full_name) #=> ["John Resig", "John Doe"]
User.find_by_full_name("Doe").map(&:full_name) #=> ["John Doe", "Philips Doeringer"]
User.find_by_full_name("John Doe").map(&:full_name) #=> ["John Doe"]

もっとのfind_by_full_name方法はこちら少り不格好になる。

だって、またカラムfull_nameを取得するそれぞれの時間によるフィルタを保存した後、concatのとします。その発見者の名前、特にファジィメモリのこの人があります。なので思'Doeに"その人のいずれかの最初と最後の名前できない簡単なユーザーです。find_by_full_name('Doe')としてお返しするために全力をできるだけ多くの更なる端子です。

ので、カラムで検索できますので、簡条件[...])条項を付すればいいのようなもの Project.find(:all,:include => :users, :conditions=>['users.full_name LIKE ?', query]) 場所

#project.rb
has_many :assignments
has_many :users, :through=>:assignments

#user.rb
has_many :assignments
has_many :projects, :through => :assignments

#assignment.rb
belongs_to :user
belongs_to :project

嬉しい休日 N

役に立ちましたか?

解決

できれnamed_scopeにユーザーです。rb

named_scope :find_by_full_name, lambda {|full_name| 
  {:conditions => {:first => full_name.split(' ').first, 
     :last => full_name.split(' ').last}}
}

しています User.find_by_full_name('John Carver')

新しいものの変化に対応した要件

named_scope :find_by_full_name, lambda {|full_name| 
  {:conditions => ["first LIKE '%?%' or last LIKE '%?%'", 
    full_name.split(' ').first, full_name.split(' ').last]}}

他のヒント

このジムの答えである。感謝。ただ、若干の変更ものです。この電流コードの原因でゆったり載中。私は少し乱れが存中の名前と化合物の氏名(ジャン-クロード-ヴァンダムの"キックボクサー").べにの名は、last_nameます。

named_scope :find_by_full_name, lambda { |full_name| 
 {:conditions => {:first_name => full_name.split(' ').first, 
   :last_name => full_name.split(' ')[1, full_name.split(' ').length-1].join(' ')}
   }
}

もちろん、どんなクリーナーをすることを歓迎いたします。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top