mongodb查询案例,golang库mgo案例

梁十八 · · 1525 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

pipeline := []bson.M{
   bson.M{"$match": bson.M{"id": uid}},
   bson.M{"$project": bson.M{"last_msg": 1, "_id": 0}},
   bson.M{"$unwind": "$last_msg"},
   bson.M{"$sort": bson.M{"last_msg": -1}},
   bson.M{"$skip": 2},
   bson.M{"$limit": 2},
}
userModel := MongoDb.C("user")
pipe := userModel.Pipe(pipeline)
var data []interface{}
err := pipe.All(&data)
fmt.Println(data)
fmt.Println(len(data))

等效于

db.getCollection("user").aggregate([
    {$match: {"id":"1"}},
    {$project:{"last_msg":1, "_id":0}},
    {$unwind: "$last_msg"},
    {$sort: {"last_msg.date":-1}},
    {$skip:2},
    {$limit:2}
]);

mongodb表结构:

图片.png

其中一条数据:

{
    "_id": ObjectId("5d2b24c16197934ef6db77ba"),
    "id": "1",
    "account": "你的女神",
    "passwd": "5d78eb174d633345054faf7d56a612ed",
    "friends": [
        {
            "uid": "2"
        },
        {
            "uid": "3"
        }
    ],
    "last_msg": [
        {
            "date": "1234567890",
            "from_id": "2",
            "msg": "在么"
        },
        {
            "date": "1234567895",
            "from_id": "3",
            "msg": "女神"
        },
        {
            "date": "1234567898",
            "from_id": "4",
            "msg": "求你了,理理我好么"
        },
        {
            "date": "1234567999",
            "from_id": "5",
            "msg": "你是不是在和别人..."
        }
    ]
}



有疑问加站长微信联系(非本文作者)

本文来自:51CTO博客

感谢作者:梁十八

查看原文:mongodb查询案例,golang库mgo案例

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1525 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传