怎么新建MySQL数据库

发布时间:2021-05-15 作者:admin
阅读:796

       这篇文章主要介绍的是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进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

二维码-群英

长按识别二维码并关注微信

更方便到期提醒、手机管理

7*24 全天候服务

售前 400-678-4567

售后 0668-2555666

售后 400 678 4567

信息安全 0668-2555 118

域名空间 3004329145