mongodb的golang驱动怎么用?golang驱动用法教程
Admin 2021-05-15 群英技术资讯 1569 次浏览
这篇文章主要介绍的是mongodb的golang驱动的使用,包括导入,链接,删除慢,查询等操作,感兴趣的朋友可以参考参考,下面就跟随小编一起来学习吧。
mongo数据库在nodejs平台有2个常用驱动,mongodb和mongoose,mongodb接口非常接近mongo数据库原生的操作方式,是helloworld之类演示代码的首选mongo数据库连接驱动,因此成为大部分nodejs初学者最先接触的mongo数据库驱动。初学者在学会mongo连接的同时,却也可悲的被helloword这种演示性质的数据库操作习惯潜移默化了。
使用教程如下:
导入
go get github.com/mongodb/mongo-go-driver/mongo
链接mongo服务
if client, err = mongo.Connect(getContext(), 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); err != nil {
checkErr(err)
}
fmt.Printf("InsertMany插入的消息ID:%v\n", insertManyRes.InsertedIDs)
查询单条数据
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)
}
fmt.Printf("Find查询到的数据:%v\n", howieArrayEmpty)
查询集合里面有多少数据
if size, err = collection.Count(getContext(), nil); err != nil {
checkErr(err)
}
fmt.Printf("Count里面有多少条数据:%d\n", size)
查询集合里面有多少数据(查询createtime>=3的数据)
if size, err = collection.Count(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)
总结
关于mongodb的golang驱动的内容就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。想要了解更多mongodb的golang驱动的使用技巧,可以关注其他相关文章。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
mongodb服务报错1067解决方法:1、删除mongodb服务并新建一个服务。2、删除mongod.lock文件。
MongoDB 排序 MongoDB sort() 方法 在 MongoDB 中使用 sort() 方法对数据进行排序,sort() 方法可以通过参数指定排序的字段,并使用 1 和 -1 来指定排序的方式,其中 1 为升序排列,而 -1 是用于降序排列。 语法 sort()方法基本语法如下所示: >db.COLLECTION_NAME.find().sort({KEY:1}) 实例 col 集合中的数据如下: { �..
MapReduce是什么,使用方法是怎样的?有不少朋友对此感兴趣,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考,下面我们一起来了解一下吧。
mongodb复制集搭建步骤:1、为不同节点创建不同的db文件夹;2、启动三个节点;3、连接主节点,并启动副本集;4、添加从节点,仲裁节点;5、测试复制集secondary节点数据复制功能;6、测试复制集主从节点故障转移功能。
MongoDB中更新文档的update()方法:1、命令为db.collection.update( criteria, objNew, upsert, multi );2、参数criteria用于指定一个查询,查询选择将要更新的目标记。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008