复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50func (this *Mongodb) StoreRecords(dbName, collection, storeDbName, tmpCollection string, queryMap, selecter bson.M) (err error) { session := this.GetSession() defer session.Close() iter := session.DB(dbName).C(collection).Find(queryMap).Select(selecter).Iter() oneMap := make(bson.M) historyMapSlice := make([]interface{}, 0, MAX_BULK_WRITE_FILE_LEN) flag := false for iter.Next(&oneMap) { tmpMap := DeepCopy(oneMap)//go深度拷贝 historyMapSlice = append(historyMapSlice, tmpMap.(bson.M)) if len(historyMapSlice) >= MAX_BULK_WRITE_FILE_LEN {//写入最大长度 this.BulkInsert(storeDbName, tmpCollection, historyMapSlice) historyMapSlice = make([]interface{}, 0, MAX_BULK_WRITE_FILE_LEN) flag = true } } if err = iter.Close(); err != nil { log.Error("StoreRecords,iter.Close() fail, db:", dbName, ", Collection:", collection, ", queryCondition:", queryMap, ", selector:", selecter, ", ErrInfo:", err) } if 0 == len(historyMapSlice) && !flag { err = errors.New("not found StoreRecords data") return } this.BulkInsert(storeDbName, tmpCollection, historyMapSlice) return } func (this *Mongodb) BulkInsert(dataBase, collection string, allRecords []interface{}) (err error) { if 0 == len(allRecords) { log.Info("bulkInsert: 0 == len(allRecords)! db:", dataBase, "collection:", collection) return } bulkInsert := func(c *mgo.Collection) error { bulk := c.Bulk() bulk.Unordered() bulk.Insert(allRecords...) _, err := bulk.Run() return err } err = this.WitchCollection(dataBase, collection, bulkInsert) if err != nil { log.Error("mongodb BulkInsert, BulkInsert Failed, db:", dataBase, ", Collection:", collection, ", ErrInfo:", err) } return }
最后
以上就是悲凉电源最近收集整理的关于go mongodb Iter迭代器示例的全部内容,更多相关go内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复