登录
首页 >  Golang >  Go问答

重新考虑仅针对子数组的数据库查询

来源:stackoverflow

时间:2024-04-11 18:12:33 209浏览 收藏

小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《重新考虑仅针对子数组的数据库查询》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

问题内容

假设我在表中有一个名为警报的对象,例如

{ id:"1"
   history:[ {
            date:"some date"
            hid:"1234"
          },
         { 
          date:"some date"
          hid:"1234"
         }
       ]
  }
 { id:"2"
   history:[ {
            date:"some other date"
            hid:"1235"
          },
         { 
          date:"some date"
          hid:"1234"
         }
       ]
  }

我想要一个仅包含所有警报的历史对象的数组。如果我使用诸如

之类的勇气
r.db("irrelevant").table("alerts").pluck("history")

我最终得到了带有括号的整个结构,只是没有 id。喜欢

{
  history:[{hid:123,date:"some date"}{hid:123,date:"some date"}]
},
{
  history:[{hid:123,date:"some date"}{hid:123,date:"some date"}]
 }

当我想要的是

[{hid:123,date:"some date"},{hid:123,date:"some date"},{hid:123,date:"some date"},{hid:123,date:"some date"}]

我专门在 go 中执行此操作,但如果我能找到 rethinkdb javascript 查询,我可能可以将其转换为 go


解决方案


您需要使用concatMap命令

r.db("irrelevant").table("alerts").concatMap(r.row.getField('history'))

理论要掌握,实操不能落!以上关于《重新考虑仅针对子数组的数据库查询》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>