首页
学习
活动
专区
圈层
工具
发布

迭代IDs
EN

Stack Overflow用户
提问于 2014-06-13 01:58:29
回答 2查看 472关注 0票数 1

有人建议我不要将数组存储在我的DB中,而是只存储ID。在我的项目中,我存储行项的In。如果我没有line_item对象,而只有it,那么我还能反复遍历一个循环来获取与它相关的所有数据吗?

为了进一步解释..。

传统上我觉得我

代码语言:javascript
复制
@line_item
>> <LineItem id: 63, product_id: 2, created_at: time, (etc) >

然后我就可以做一些事情

代码语言:javascript
复制
@line_item.title
>> "T-Shirt:Small"

但如果我做了

代码语言:javascript
复制
@line_item

并得到了

代码语言:javascript
复制
>>[12, 14]

我能做一个@line.item.each,从视图中的in获取所有我需要的信息吗?还是我要自己创造一个可怕的方法?

希望我已经提出了我的问题是可以理解的。

谢谢。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-06-13 02:06:53

你可以这样做:

代码语言:javascript
复制
@items = [12,14]  # your list of ids you got from somewhere
@items.each do |id|
   @line_item = LineItem.find(id)  # Get the instance for that id.
   # do stuff.
end

你也可以这样做:

代码语言:javascript
复制
@line_items = LineItem.find(@id_list)

如果您存储is列表的原因是捕获关系,那么您应该查看rails提供的belongs_to和has_many关系。通过存储列表来实现数据的去正常化是很讨厌的,因为你不知道你的列表会有多长。它阻止您的数据库正确地建立索引,而且很难维护。

票数 1
EN

Stack Overflow用户

发布于 2014-06-13 02:17:57

我建议你使用:

代码语言:javascript
复制
LineItem.where(id: [12,14])

因为它将始终返回一个项目数组。如果试图查找不在数据库中的项,则会发现记录未找到错误。如果找不到记录,这将呈现一个空数组。

只要您有一个数组,不管是否为空,您就不必拯救.each方法,因为它在任何情况下都不会失败。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24196591

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档