golang连接MongoDB数据库及数据库操作指南
作者:monzaid 发布时间:2024-01-26 18:14:29
标签:golang,mongodb,连接
安装配置MongoDB驱动
安装驱动
go get -u github.com/mongodb/mongo-go-driver
初始化模块
go mod init 模块名称
执行go mod tidy
go mod tidy
导入驱动
import (
"context"
"go.mongodb.org/mongo-driver/bson" //BOSN解析包
"go.mongodb.org/mongo-driver/mongo" //MongoDB的Go驱动包
"go.mongodb.org/mongo-driver/mongo/options"
)
获得数据库连接
初始化连接
package main
import (
"context"
"fmt"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
)
var client *mongo.Client
func initDB() (err error) {
// 设置客户端连接配置
clientOptions := options.Client().ApplyURI("mongodb://ip:port")
// 连接到MongoDB
client, err = mongo.Connect(context.TODO(), clientOptions)
if err != nil {
return err
}
// 检查连接
err = client.Ping(context.TODO(), nil)
if err != nil {
return err
}
return nil
}
func main() {
err := initDB() // 调用输出化数据库的函数
if err != nil {
fmt.Printf("初始化失败!,err:%v\n", err)
return
}else{
fmt.Println("Connected to MongoDB!")
}
}
连接MongoDB的Go驱动程序中有两大类型表示BSON数据:D和Raw。
类型D家族被用来简洁地构建使用本地Go类型的BSON对象。这对于构造传递给MongoDB的命令特别有用。D家族包括四类:
D:一个BSON文档。这种类型应该在顺序重要的情况下使用,比如MongoDB命令。
bson.D{{"foo", "bar"}, {"hello", "world"}, {"pi", 3.14159}}
M:一张无序的map。它和D是一样的,只是它不保持顺序。
bson.M{"foo": "bar", "hello": "world", "pi": 3.14159}
A:一个BSON数组。
bson.A{"hello", "world", 3.14159, bson.D{{"abcde", 12345}}}
E:D里面的一个元素。
要使用BSON,需要先导入下面的包:
import "go.mongodb.org/mongo-driver/bson"
Raw类型家族用于验证字节切片。你还可以使用Lookup()从原始类型检索单个元素。如果你不想要将BSON反序列化成另一种类型的开销,那么这是非常有用的。
数据库操作
添加文档
添加单个文档
使用collection.InsertOne()方法插入一条文档记录:
func insertOne(s interface{}) (err error) {
collection := client.Database("datebase").Collection("collection")
insertResult, err := collection.InsertOne(context.TODO(), s)
if err != nil {
return err
}
fmt.Println("Inserted a single document: ", insertResult.InsertedID)
return nil
}
测试:
s := struct{name string
age int
}{"tom", 20}
err := insertOne(s)
if err != nil{
fmt.Printf("添加文档失败!,err:%v\n", err)
}
添加多个文档
使用collection.InsertMany()方法插入多条文档记录:
func insertMore(s []interface{}) (err error) {
//students := []interface{}{s2, s3}
collection := client.Database("datebase").Collection("collection")
insertManyResult, err := collection.InsertMany(context.TODO(), s)
if err != nil {
return err
}
fmt.Println("Inserted multiple documents: ", insertManyResult.InsertedIDs)
return nil
}
测试:
type Student struct {
name string
age int
}
s1 := Student{name: "tom", age: 20}
s2 := Student{name: "kite", age: 21}
s3 := Student{name: "rose", age: 22}
ss := []interface{}{s1, s2, s3}
insertMore(ss)
if err != nil{
fmt.Printf("添加多个文档失败!,err:%v\n", err)
}
查找文档
func find() (err error){
ctx, cancel := context.WithTimeout(context.Background(), 30*time.Second)
defer cancel()
collection := client.Database("datebase").Collection("collection")
cur, err := collection.Find(ctx, bson.D{})
if err != nil {
return err
}
defer cur.Close(ctx)
for cur.Next(ctx) {
var result bson.D
err := cur.Decode(&result)
if err != nil {
return err
}
fmt.Printf("result: %v\n", result)
}
if err := cur.Err(); err != nil {
return err
}
return nil
}
更新文档
func update() (err error) {
ctx := context.TODO()
defer client.Disconnect(ctx)
c := client.Database("datebase").Collection("collection")
update := bson.D{{"$set", bson.D{{"attr1", "value1"}, {"attr2", "value2"}}}}
ur, err := c.UpdateMany(ctx, bson.D{{"old_attr1", "old_value1"}}, update)
if err != nil {
return err
}
fmt.Printf("ur.ModifiedCount: %v\n", ur.ModifiedCount)
return nil
}
删除文档
func del() (err error) {
c := client.Database("datebase").Collection("collection")
ctx := context.TODO()
dr, err := c.DeleteMany(ctx, bson.D{{"attr1", "value1"}})
if err != nil {
return err
}
fmt.Printf("ur.ModifiedCount: %v\n", dr.DeletedCount)
return nil
}
来源:https://blog.csdn.net/ymxyld/article/details/124931029


猜你喜欢
- 定义返回单值def my_abs(x): if x >= 0: return x &
- 利用Python生成PDF文件时,对比了fpdf和reportlab两个库。fpdf最新更新还是2015年,另外reportlab的资料网上
- python简单实现最大似然估计1、scipy库的安装wim+R输入cmd,然后cd到python的pip路径,即安装:pip instal
- 在oracle中有很多关于日期的函数,如:1、add_months()用于从一个日期值增加或减少一些月份date_value:=add_mo
- 昨天写了一段用来做分层随机抽样的代码,很粗糙,不过用公司的2万名导购名单试了一下,结果感人,我觉得此刻的我已经要上天了,哈哈哈哈哈哈代码如下
- Microsoft office Access Database Engine 错误 '80040e14' Insert I
- 本文介绍了python的构建工具setup.py,分享个大家,具体如下:一、构建工具setup.py的应用场景在安装python的相关模块和
- 下面就是今天下午的研究成果。发布系统需要响应用户的中断请求,需要在GET方法中杀掉由subprocess派生的子进程,刚开始直接用os.ki
- 前言我们的游戏资源处理工具是Python实现的,功能包括csv解析,UI材质处理,动画资源解析、批处理,Androd&iOS自动打包
- 首先要写连接字符串可以在web.config里写上<connectionStrings>
- 题目:给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。示例:示例 1:输入: “abcabcbb”输出: 3解释: 因为无重
- 今天在看实验室的项目时,碰到了一个让我“棘手”的问题,其实也是自己太笨了。先把 sql 语句扔出来// 这条语句在id没有1时,不能得到正确
- 大家好,之前我们使用 WechatPCAPI 做了获取微信好友信息以及查看撤回消息,本文我们再使用 WechatPCAPI 来实现微信自动回
- 1、使用索引来更快地遍历表。缺省情况下建立的索引是非群集索引,但有时它并不是最佳的。在非群集索引下,数据在物理上随机存放在数据页上。合理的索
- 一、元素偏移量 offset 系列offset 翻译过来就是偏移量, 我们使用 offset 系列相关属性可以动态的得到该元素的位置(偏移)
- 今天同事 明城 在项目中碰到一个 BUG,代码具体如下:<!DOCTYPE html PUBLIC "-//W3C//DTD
- 1 from multiprocessing import Pool,Queue。其中Queue在Pool中不起作用,具体原因未明。解决方案
- 深入解析Linux下MySQL数据库的备份与还原 1. 备份 [root@localhost ~]# cd /var/lib/mysql (
- 例如:select (a+b) as c from 表 类型也一致都是varchar型的,可就是显示不正确。 直到concat() MySQ
- 备注 与 DELETE 语句相比,TRUNCATE TABLE 具有以下优点: 所用的事务日志空间较少。 DELETE 语句每次删除一行,并