0

我正在尝试将数据库中的多个值检索到单个变量中并返回整个内容。这是我正在做的

my_hash = {
  'name' => 'John'
  'current_location' => 'Sweden'
}

现在我需要进入数据库并检索所有记录并将它们存储到一个变量中,然后我需要将该变量添加到 my_hash 中,以便我可以返回整个内容。我该怎么做?

例子:

last_names = Names.where('first_name = ?', 'John').select('last_name').last_name
my_hash.add(last_names)
return my_hash

现在上面不起作用,有人可以告诉我实现这一目标的正确方法吗?

4

1 回答 1

1

您是否正在尝试执行以下操作?

my_hash = {
  'name' => 'John'
  'current_location' => 'Sweden'
}

my_hash['last_names'] = Names.where('first_name = ?', 'John')
  .select('last_name')
  .map { |name| name.last_name } 
# or shorthand version .map(&:last_name)

return my_hash

更新

# get name objects from the database 
# add select as an optimization if desired
last_name_list = Names.where('first_name = ?', 'John')
# get an array of only the last_name fields
last_names = last_name_list.map { |name| name.last_name }
# assign the array to the new hash key 'last_names'
my_hash['last_names'] = last_names

有关地图的文档,请参阅http://www.ruby-doc.org/core-1.9.3/Array.html#method-i-map,请注意地图和收集是相同的

另一个例子

names = Names.where('updated_at >= ?', Date.parse('2013-01-01'))

# get an array of 'full names'
full_names = names.map do |name| 
  "#{name.first_name} #{name.last_name}"
end
于 2013-07-23T17:31:57.747 回答