doutuo6689 2015-02-23 10:37
浏览 167
已采纳

如何使用mongodb中的golang从json数组中获取嵌套值

I am having the below json

I want to extract the value of particular Data from Requirement array based on Id. If "Data" = "String123" it should display the "Data" as ["WED"].

I tried this code

but I am getting all values irrespective of Id.

  • 写回答

2条回答 默认 最新

  • douhui8025 2015-02-23 11:42
    关注

    If I get you right you have one record in "clOfferMaster" collection and you're trying to fetch data from nested collection "Eligibility". That's probably not a typical way to work with data.

    What if you restructure your data as follows:

    [ 
        {
            "ComponentId" : "SessionDayCheck",
            "ConfigData" : [ 
                "WED"
            ]
        }, 
        {
            "ComponentId" : "TransDayCheck",
            "ConfigData" : [ 
                "WED", 
                "THU"
            ]
        }, 
        {
            "ComponentId" : "SessionTransCheck",
            "ConfigData" : ""
        }
    ]
    

    It that case you can do the following query

    c := session.DB("offerengine2").C("clOfferMaster")
    
    var result struct {
        ConfigData []string "ConfigData"
    }
    err = c.Find(bson.M{"ComponentId": "SessionDayCheck"}).One(&result)
    if err != nil {
        log.Fatal(err)
    }
    
    fmt.Println("Result:", result)
    // Result: {[WED]} 
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 教务系统账号被盗号如何追溯设备
  • ¥20 delta降尺度方法,未来数据怎么降尺度
  • ¥15 c# 使用NPOI快速将datatable数据导入excel中指定sheet,要求快速高效
  • ¥15 再不同版本的系统上,TCP传输速度不一致
  • ¥15 高德地图点聚合中Marker的位置无法实时更新
  • ¥15 DIFY API Endpoint 问题。
  • ¥20 sub地址DHCP问题
  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式