go任务调度10(操作mongodb)

栏目: 数据库 · 发布时间: 5年前

内容简介:后台启动mongodb服务器端:注意:从github.com/mongodb/mongo-go-driver下载下来要放到go.mongodb.org目录对应的位置,不然会报错

后台启动 mongodb 服务器端:

nohup ./bin/mongod --dbpath=./data &
package main

//导入
import (
    "context"
    "fmt"
    "go.mongodb.org/mongo-driver/bson"
    "go.mongodb.org/mongo-driver/bson/primitive"
    "go.mongodb.org/mongo-driver/mongo"
    "go.mongodb.org/mongo-driver/mongo/options"
    "go.mongodb.org/mongo-driver/mongo/readpref"
    "os"
    "time"
)

type Howie struct {
    //struct里面获取ObjectID
    HowieId    primitive.ObjectID `bson:"_id"`
    Name       string
    Pwd        string
    Age        int64
    CreateTime int64
}

func main() {
    TestMongo("mongodb://0.0.0.0:27017")
}

func TestMongo(url string) {
    var (
        err             error
        client          *mongo.Client
        collection      *mongo.Collection
        insertOneRes    *mongo.InsertOneResult
        insertManyRes   *mongo.InsertManyResult
        delRes          *mongo.DeleteResult
        updateRes       *mongo.UpdateResult
        cursor          *mongo.Cursor
        howieArray      = GetHowieArray()
        howie           Howie
        howieArrayEmpty []Howie
        size            int64
    )
    //链接mongo服务
    if client, err = mongo.Connect(getContext(), options.Client().ApplyURI(url)); err != nil {
        checkErr(err)
    }
    //判断服务是否可用
    if err = client.Ping(getContext(), readpref.Primary()); err != nil {
        checkErr(err)
    }
    //选择数据库和集合
    collection = client.Database("testing_base").Collection("howie")

    //删除这个集合
    collection.Drop(getContext())

    //插入一条数据
    if insertOneRes, err = collection.InsertOne(getContext(), howieArray[0]); err != nil {
        checkErr(err)
    }

    fmt.Printf("InsertOne插入的消息ID:%v\n", insertOneRes.InsertedID)
    //批量插入数据
    if insertManyRes, err = collection.InsertMany(getContext(), howieArray[1:]); err != nil {
        checkErr(err)
    }
    fmt.Printf("InsertMany插入的消息ID:%v\n", insertManyRes.InsertedIDs)
    var Dinfo = make(map[string]interface{})
    err = collection.FindOne(getContext(), bson.D{{"name", "howie_2"}, {"age", 11}}).Decode(&Dinfo)
    fmt.Println(Dinfo)
    fmt.Println("_id", Dinfo["_id"])

    //查询单条数据
    if err = collection.FindOne(getContext(), bson.D{{"name", "howie_2"}, {"age", 11}}).Decode(&howie); err != nil {
        checkErr(err)
    }
    fmt.Printf("FindOne查询到的数据:%v\n", howie)

    //查询单条数据后删除该数据
    if err = collection.FindOneAndDelete(getContext(), bson.D{{"name", "howie_3"}}).Decode(&howie); err != nil {
        checkErr(err)
    }
    fmt.Printf("FindOneAndDelete查询到的数据:%v\n", howie)

    //查询单条数据后修改该数据
    if err = collection.FindOneAndUpdate(getContext(), bson.D{{"name", "howie_4"}}, bson.M{"$set": bson.M{"name": "这条数据我需要修改了"}}).Decode(&howie); err != nil {
        checkErr(err)
    }
    fmt.Printf("FindOneAndUpdate查询到的数据:%v\n", howie)

    //查询单条数据后替换该数据(以前的数据全部清空)
    if err = collection.FindOneAndReplace(getContext(), bson.D{{"name", "howie_5"}}, bson.M{"hero": "这条数据我替换了"}).Decode(&howie); err != nil {
        checkErr(err)
    }

    fmt.Printf("FindOneAndReplace查询到的数据:%v\n", howie)
    //一次查询多条数据
    // 查询createtime>=3
    // 限制取2条
    // createtime从大到小 排序 的数据
    if cursor, err = collection.Find(getContext(), bson.M{"createtime": bson.M{"$gte": 2}}, options.Find().SetLimit(2), options.Find().SetSort(bson.M{"createtime": -1})); err != nil {
        checkErr(err)
    }
    if err = cursor.Err(); err != nil {
        checkErr(err)
    }
    defer cursor.Close(context.Background())
    for cursor.Next(context.Background()) {
        if err = cursor.Decode(&howie); err != nil {
            checkErr(err)
        }
        howieArrayEmpty = append(howieArrayEmpty, howie)
    }
    for _, v := range howieArrayEmpty {
        fmt.Printf("Find查询到的数据ObejectId值%s 值:%v\n", v.HowieId.Hex(), v)
    }
    //查询集合里面有多少数据
    if size, err = collection.CountDocuments(getContext(),bson.D{}); err != nil {
        checkErr(err)
    }
    fmt.Printf("Count里面有多少条数据:%d\n", size)

    //查询集合里面有多少数据(查询createtime>=3的数据)
    if size, err = collection.CountDocuments(getContext(), bson.M{"createtime": bson.M{"$gte": 3}}); err != nil {
        checkErr(err)
    }
    fmt.Printf("Count里面有多少条数据:%d\n", size)

    //修改一条数据
    if updateRes, err = collection.UpdateOne(getContext(), bson.M{"name": "howie_2"}, bson.M{"$set": bson.M{"name": "我要改了他的名字"}}); err != nil {
        checkErr(err)
    }
    fmt.Printf("UpdateOne的数据:%d\n", updateRes)

    //修改多条数据
    if updateRes, err = collection.UpdateMany(getContext(), bson.M{"createtime": bson.M{"$gte": 3}}, bson.M{"$set": bson.M{"name": "我要批量改了他的名字"}}); err != nil {
        checkErr(err)
    }

    fmt.Printf("UpdateMany的数据:%d\n", updateRes)
    //删除一条数据
    if delRes, err = collection.DeleteOne(getContext(), bson.M{"name": "howie_1"}); err != nil {
        checkErr(err)
    }
    fmt.Printf("DeleteOne删除了多少条数据:%d\n", delRes.DeletedCount)

    //删除多条数据
    if delRes, err = collection.DeleteMany(getContext(), bson.M{"createtime": bson.M{"$gte": 7}}); err != nil {
        checkErr(err)
    }
    fmt.Printf("DeleteMany删除了多少条数据:%d\n", delRes.DeletedCount)

}

func checkErr(err error) {
    if err != nil {
        if err == mongo.ErrNoDocuments {
            fmt.Println("没有查到数据")
            os.Exit(0)
        } else {
            fmt.Println(err)
            os.Exit(0)
        }

    }
}

func getContext() (ctx context.Context) {
    ctx, _ = context.WithTimeout(context.Background(), 10*time.Second)
    return
}

func GetHowieArray() (data []interface{}) {
    var i int64
    for i = 0; i <= 10; i++ {
        data = append(data, Howie{
            HowieId:    primitive.NewObjectID(),
            Name:       fmt.Sprintf("howie_%d", i+1),
            Pwd:        fmt.Sprintf("pwd_%d", i+1),
            Age:        i + 10,
            CreateTime: i + 1,
        })
    }
    return
}

注意:从github.com/mongodb/mongo-go-driver下载下来要放到go.mongodb.org目录对应的位置,不然会报错


以上所述就是小编给大家介绍的《go任务调度10(操作mongodb)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

如何求解问题

如何求解问题

Zbigniew Michalewicz、David B.Fogel / 曹宏庆 / 中国水利水电出版社 / 2003-2-1 / 35.00元

《如何求解问题:现代启发式方法》通过一系列贯穿于章节间的有趣难题,《如何求解问题:现代启发式方法》深入浅出地阐述了如何利用计算机来求解问题的一些现代启发式方法。全书包括两部分,共分15章。一起来看看 《如何求解问题》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具