dongping4273 2017-08-28 11:19
浏览 42


I have a collector module that pulls a remote API every 30 seconds. That gives me a list of objects that I insert or update in a MongoDB database.

   "id" : "oulkhhvoiupokb",
   "name" : "test1",
   "status" : "OPEN"
   "id" : "oulkhhvoisksbsjkkb",
   "name" : "test2",
   "status" : "CLOSED"

In fact, I only collect the objects that have the OPEN status. And with a loop, I set the rest of the object as CLOSED (because they are not OPEN). But in the future, it will take a lot of time because the amont of object will grow.

I work with Golang and MGO package.

Is there a way to do it faster and cleaner please ? Something like setting a basic field value for Mongo documents ?

To explain it differently, when I will insert the OPEN objects in the database, all the other ones that are already in database must be CLOSED. Can Mongo do it ?


  • 写回答

1条回答 默认 最新

  • doutu4335 2017-08-30 14:20

    Solution was to use func (c *Collection) UpdateAll(selector interface{}, update interface{}) (info *ChangeInfo, err error) with the $nin for the selector and $set for the update.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?



  • ¥15 c# ReportDocument 类执行方法PrintToPrinter()方法时报错
  • ¥15 关于#python#的问题
  • ¥15 主机可以ping通路由器但是连不上网怎么办
  • ¥15 数据库一张以时间排好序的表中,找出多次相邻的那些行
  • ¥50 关于DynamoRIO处理多线程程序时候的问题
  • ¥15 kubeadm部署k8s出错
  • ¥15 Abaqus打不开cae文件怎么办?
  • ¥20 双系统开机引导中windows系统消失问题?
  • ¥15 小程序准备上线,软件开发公司需要提供哪些资料给甲方
  • ¥15 关于生产日期批次退货退款,库存回退的问题