duangou1551 2018-04-05 10:46
浏览 619
已采纳

使用gopkg.in/mgo.v2作为字符串的golang中的自定义mongodb命令

I was wondering, is there anyway to run my own command (or query) which I have constructed as a string variable using "mgo" in go.

Something like this:

c := session.DB(DBNAME).C(COLLECTION)
c.RUN_COMMAND_AS_STRING("find({username:'vahid'})")
  • 写回答

2条回答 默认 最新

  • doxqszx09742 2018-04-13 03:37
    关注

    is there anyway to run my own command (or query) which I have constructed as a string variable using "mgo" in go.

    You can invoke MongoDB find command, and parsing string of query filter to map[string]interface{}.

    For example:

    db := session.DB("databaseName")
    
    queryString := `{"username":"sergio"}`
    var filter map[string]interface{} 
    err = json.Unmarshal([]byte(queryString), &filter)
    
    result := bson.M{}
    err = db.Run(bson.D{{"find", "collectionName"}, {"filter", filter}}, &result)
    fmt.Println(result)
    

    Alternatively, instead of using find(), depending on your use case, you can also use MongoDB Aggregation Pipeline.

    For example:

    pipeString := `[{"$match":{"username":"sergio"}}, {"$project":{"newfield":"$username"}}]`
    
    pipe := []bson.M{}
    err = json.Unmarshal([]byte(pipeString), &pipe)
    
    coll := session.DB("databaseName").C("collectionName")
    response := []bson.M{}
    err = coll.Pipe(pipe).All(&response)  
    fmt.Println(response)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

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