遍历元素并将其插入MongoDB
来源:stackoverflow
时间:2024-02-07 23:51:21 136浏览 收藏
对于一个Golang开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《遍历元素并将其插入MongoDB》,主要介绍了,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!
我遇到一个问题,不知道如何解决。我有一个 go 端点来读取 txt 文件的内容并返回其内容。该文件的结构如下:
usertest1,usertest1 usertest2,usertest2
第一步是读取行并在逗号处分割。当我得到结果时,这工作得很好:
[ { name: userttest1 surname: usertest1 }, { name: userttest1 surname: usertest1 } ]
这个逻辑与下面的代码块配合得很好
var dataslice = make([]element, 0) lines := strings.split(string(filebytes), "\n") var txt *models.textparser if err := ctx.shouldbindjson(&txt); err != nil { ctx.json(http.statusbadrequest, err.error()) return } for _, line := range lines { keyval := strings.split(line, ",") dataslice = append(dataslice, element{name: keyval[0], surname: keyval[1]}) ctx.json(http.statusok, dataslice) }
我的元素如下所示:
type element struct { name string `json:"name" bson:"name"` surname string `json:"surname" bson:"surname"` }
但现在我想测试这个循环并将每个元素插入 mongo 数据库中。所以我从我的模型开始
型号:
type textparser struct { name string `json:"name" bson:"name"` surname string `json:"surname" bson:"surname"` createat time.time `json:"created_at" bson:"created_at"` updatedat time.time `json:"updated_at" bson:"updated_at"` } type dbtxt struct { id primitive.objectid `json:"id" bson:"_id"` name string `json:"name" bson:"name"` surname string `json:"surname" bson:"surname"` createat time.time `json:"created_at" bson:"created_at"` updatedat time.time `json:"updated_at" bson:"updated_at"` }
这是我的短信服务:
type txtservice interface { createtxt(*models.textparser) (*models.dbtxt, error) }
这是文本服务实现:
type txtserviceimpl struct { txtcollection *mongo.collection ctx context.context } func newtextservice(txtcollection *mongo.collection, ctx context.context) txtservice { return &txtserviceimpl{txtcollection, ctx} } func (t txtserviceimpl) createtxt(text *models.textparser) (*models.dbtxt, error) { text.createat = time.now() text.updatedat = text.createat res, err := t.txtcollection.insertone(t.ctx, text) var newtxt *models.dbtxt query := bson.m{"_id": res.insertedid} if err = t.txtcollection.findone(t.ctx, query).decode(&newtxt); err != nil { return nil, err } return newtxt, nil }
现在我已经拥有了向 mongo db 实际添加值所需的所有代码。我更新了控制器以执行数据库插入。我的逻辑(实际上完全错误)是,当循环运行并更新我的元素数组时,我可以使用该循环将值插入 mongo 数据库中。所以我做了以下事情:
var dataslice = make([]element, 0) lines := strings.split(string(filebytes), "\n") var txt *models.textparser if err := ctx.shouldbindjson(&txt); err != nil { ctx.json(http.statusbadrequest, err.error()) return } for _, line := range lines { keyval := strings.split(line, ",") dataslice = append(dataslice, element{name: keyval[0], surname: keyval[1]}) newtxt, err := tc.txtservice.createtxt(dataslice) if err != nil { if strings.contains(err.error(), "title already exists") { ctx.json(http.statusconflict, gin.h{"status": "fail", "message": err.error()}) return } ctx.json(http.statusbadgateway, gin.h{"status": "fail", "message": err.error()}) return ctx.json(http.statuscreated, gin.h{"status": "success", "data": newtxt}) } }
当我尝试运行该项目时,出现以下错误:
#13 15.09 controllers/parser.controller.go:77:42: cannot use dataSlice (variable of type []Element) as *models.TextParser value in argument to tc.txtService.CreateTxt ------ failed to solve: rpc error: code = Unknown desc = executor failed running [/bin/sh -c go install -v ./...]: exit code: 1
如果有人可以帮助理解我的错误,我将不胜感激。
正确答案
您似乎想通过调用 createtxt
来单独插入每个文档。
要插入的文档是 textparser
类型(也许名称 parsedtext
更合适,因为它只是一个数据对象而不是解析器)。
获得 element
切片后,您希望将其转换为 parsedtext
,并可能在 created_at
和 updated_at
数据库字段中添加当前时间。
可以对 element
类型的每个 el
执行此操作,如下所示:
doc := parsedtext{ el.name, el.surname, time.now(), time.now(), }
也许将解析功能提取到单独的函数中是个好主意。例如,这可以称为 parse
并返回元素的切片。
func parse() ([]element, error)
一个有效的、简化的、独立的示例可能看起来像这样:
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" "log" "time" ) type element struct { name string `json:"name" bson:"name"` surname string `json:"surname" bson:"surname"` } type parsedtext struct { name string `json:"name" bson:"name"` surname string `json:"surname" bson:"surname"` createat time.time `json:"created_at" bson:"created_at"` updatedat time.time `json:"updated_at" bson:"updated_at"` } type dbtxt struct { id primitive.objectid `json:"id" bson:"_id"` name string `json:"name" bson:"name"` surname string `json:"surname" bson:"surname"` createat time.time `json:"created_at" bson:"created_at"` updatedat time.time `json:"updated_at" bson:"updated_at"` } func createtxt(ctx context.context, collection *mongo.collection, text *parsedtext) (*dbtxt, error) { res, err := collection.insertone(context.todo(), text) if err != nil { return nil, err } var newtxt *dbtxt query := bson.m{"_id": res.insertedid} if err = collection.findone(ctx, query).decode(&newtxt); err != nil { return nil, err } return newtxt, nil } func parse() ([]element, error) { return []element{ {name: "c.j.", surname: "cherryh"}, {name: "george", surname: "orwell"}, }, nil } func main() { ctx := context.todo() client, err := mongo.connect(ctx, options.client().applyuri("mongodb://localhost:27017")) if err != nil { log.fatal(err) } defer client.disconnect(ctx) collection := client.database("db").collection("elements") dataslice, err := parse() if err != nil { log.fatal(err) } for _, el := range dataslice { doc := parsedtext{ el.name, el.surname, time.now(), time.now(), } dbtxt, err := createtxt(ctx, collection, &doc) if err != nil { log.fatal(err) } fmt.printf("result: %v\n", dbtxt) } }
parse
显然只提供了一些模拟数据,但这只是为了演示转换部分。
补充说明
值得注意的是,mongodb 还提供了 insertmany()
。使用它,您可以一次插入整个切片。
如果您想采用此路线,则 createtxt
的参数可以是 dataslice []interface{}
。 dataslice
将使用 []interface{}
类型创建。您将添加几个 parsedtext
对象,类似于上面显示的代码。
插入代码看起来像这样:
res, err := t.txtCollection.InsertMany(t.ctx, dataSlice)
由于您似乎对 id 感兴趣,因此您可以使用 res.insertedids
检索它们。
好了,本文到此结束,带大家了解了《遍历元素并将其插入MongoDB》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习