Rails虚拟属性搜索或sql组合列搜索

前端之家收集整理的这篇文章主要介绍了Rails虚拟属性搜索或sql组合列搜索前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个用户模型,属性为“first”和“last”
所以例如
User.first.first#=> “查理”
User.first.last#=> “棕色”

用户模型还具有虚拟属性“full_name”

  1. #user.rb
  2. def full_name
  3. [first,last].join(' ')
  4. end
  5.  
  6. def full_name=(name) #don't know what to do with people w/ middle names
  7. split = name.split(' ')
  8. self.first = split[0]
  9. self.last = split[1]
  10. end

所以例如:

  1. User.first.full_name = "Charlie Brown" #=> "Charlie Brown"
  2. User.first.full_name = "Homer Simpson" #=> "Home Simpson"
  3. User.first.save
  4. User.first.first #=> "Homer"
  5. User.first.last #=> "Simpson"

如果我可以通过该虚拟属性进行搜索,那将是非常好的
所以例如动态查找:

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

查找条件示例:

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

我希望在sql语言中至少找到一些可以做到这一点的方法;如果有一个动态虚拟属性find,也是在strudel上的额外的香草源. (这个冬天有人吗?)

我也担心要搜索名称,例如,“Holmes”只能在“第一”列中搜索,但不能检索“last”,例如User.first.full_name#=> “夏洛克·福尔摩斯”.

我试着做一个更全面的搜索

user.rb

  1. def self.find_by_full_name(name) #returns an array of User model
  2. return all if name.blank?
  3.  
  4. split = name.split(' ',2)
  5. output = []
  6. if split.length > 1
  7. with_scope( :find => { :conditions => ['first LIKE ?',"%#{split[0]}%"] }) do
  8. output << all(:conditions => ['last LIKE ?',"%#{split[1]}%"])
  9. output.flatten!
  10. end
  11. elsif split.length == 1
  12. output << all(:conditions => ['first LIKE ?',"%#{split[0]}%"])
  13. output << all(:conditions => ['last LIKE ?',"%#{split[0]}%"])
  14. output.flatten!
  15. end
  16. end

例如

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

但是我只是认为这里的find_by_full_name方法有点笨拙.

我的意思是,如果我有一个列full_name,每次都被一个后保存过滤器设置为第一个和最后一个.所以寻找一个人的名字,特别是对这个人的模糊记忆,是有帮助的.所以如果我记得那个人的名字叫做“Doe”,我可以随便做一个简单的User.find_by_full_name(‘Doe’)返回尽可能多的进一步的定位.

因为它是一列,我可以在find(:conditions […])子句中搜索它,如果我必须像Project.find(:all,:include =>:users,:conditions => ; [‘users.full_name LIKE?’,query])
哪里

  1. #project.rb
  2. has_many :assignments
  3. has_many :users,:through=>:assignments
  4.  
  5. #user.rb
  6. has_many :assignments
  7. has_many :projects,:through => :assignments
  8.  
  9. #assignment.rb
  10. belongs_to :user
  11. belongs_to :project

节日快乐
ñ

解决方法

您可以在user.rb中使用named_scope:
  1. named_scope :find_by_full_name,lambda {|full_name|
  2. {:conditions => {:first => full_name.split(' ').first,:last => full_name.split(' ').last}}
  3. }

那么你可以做User.find_by_full_name(‘John Carver’)

应对需求变化的新东西

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

猜你在找的MsSQL相关文章