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

标签 sql ruby-on-rails find conditional-statements virtual-attribute

我有一个具有“first”和“last”属性的用户模型
所以例如
User.first.first #=> "查理"
User.first.last #=> "棕色"
这个用户模型也有一个虚拟属性“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
find 中的条件示例:
User.all(:conditions => ['full_name LIKE ?', query]) #this doesn't work
我希望至少在 SQL 语言中找到一些可以做到这一点的方法;如果也有动态虚拟属性查找,那是馅饼上的额外 Vanilla 源。 (今年冬天有人吃这个吗?)
我还担心正在搜索的名称,例如,“福尔摩斯”可能只能在“第一个”列中搜索,而不能在要检索的“最后一个”列中搜索,例如,User.first.full_name #=> "Sherlock Holmes" .
我确实尝试进行更全面的搜索:
用户名
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 每次都由后保存过滤器设置,并带有 first 和 last 的连接。所以找到一个人的名字,特别是这个人的模糊内存,是有帮助的。因此,如果我记得那个人的名字或姓氏中的“Doe”,我总是可以执行一个简单的 User.find_by_full_name('Doe') 返回尽可能多的内容以进一步确定它。
由于它是一列,如果我必须执行类似 Project.find(:all,:include => :users, :conditions=>['users.full_name LIKE ?', query]) 的操作,我可以在 find(:conditions[...]) 子句中搜索它。
在哪里
#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

最佳答案

您可以在 user.rb 中使用 named_scope:

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]}}

关于sql - Rails 虚拟属性搜索或 sql 组合列搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1806394/

相关文章:

sql - 使用 SQL Server 2008 将主键约束删除或更改为 UNIQUE 约束

SQL Server 只读权限

sql - 使用条件递归 SQL/基于条件创建列

MySQL:从 INNER JOIN 内部分组

linux - 如何使用 find 命令和 wc 命令查找目录和所有子目录中所有 .txt 文件的数量?

bash - 编写一个 shell 脚本,在 1 行中查找并输出文件名和内容

css - rails 上的 ruby : Change flash message colour without Twitter Bootstrap

ruby-on-rails - nokogiri 未安装在 ruby​​ 2.7.1 centos 7.2

ruby-on-rails - encode_www_form 将空格转换为 + 而不是 %20

python - 将 find 方法实现为资助子字符串的函数的挑战