Поиск в виртуальном атрибуте Rails или комбинированный поиск в столбце sql

У меня есть модель пользователя с атрибутамипервый' а также 'прошлой' Так, например, User.first.first # => "Чарли" User.first.last # => "Браун»

Эта модель пользователя также имеет виртуальный атрибутФИО'

#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

Пример для условий в find:

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

Я надеюсь найти хоть какие-то способы в языке SQL, которые могут это сделать; если там'Динамический виртуальный атрибут тоже находит, чтоДополнительный ванильный источник на штруделе. (у кого есть эта зима?)

Я также был обеспокоен тем, что имя ищется, например, "Холмс» можно искать только впервый' столбец, но не 'прошлой' чтобы получить, например,.User.first.full_name #=> "Sherlock Holmes"

Я попытался сделать более полный поиск:

user.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
 ["John Doe"]

Но я просто подумал, что метод find_by_full_name здесь немного громоздкий.

Я имею в виду, если бы у меня был столбец full_name, который устанавливается каждый раз фильтром после сохранения с concat first и last. Так что найти человекаИмя, особенно с нечеткой памятью об этом человеке, полезно. Так что, если я вспомнилDoe» в этом человекес именем или фамилией, я всегда могу сделать простое User.find_by_full_name ('Doe») вернуть как можно больше, чтобы закрепить его.

И так как это столбец, я могу найти его в предложении find (: условие [...]), если мне нужно сделать что-то вроде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

Ответы на вопрос(2)

Ваш ответ на вопрос