欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

mongodb使用_遍历列表中的元素,作为变量,循环修改mongodb中的字段

程序员文章站 2022-05-03 22:25:47
一、问题描述: 需要将工作界面上的一些已经离职的用户状态改为失效,并备注为离职 二、需要准备/拿到手的工具/条件/数据: 1.已离职人员名单(excel格式) 2.任意mongodb工具(笔者使用的是NoSQLBooster for Mongodb) 3.连接好的mongodb数据库(有些网络/策略 ......

一、问题描述:

  需要将工作界面上的一些已经离职的用户状态改为失效,并备注为离职

二、需要准备/拿到手的工具/条件/数据:

  1.已离职人员名单(excel格式)

  2.任意mongodb工具(笔者使用的是nosqlbooster for mongodb)

  3.连接好的mongodb数据库(有些网络/策略不同,直连无法成功的,可以尝试使用mongodb中的ssh,在笔者的连接工具/connections/edit/ssh中可以进行设置)

修改mongodb中列表中多个元素,遍历其中的元素,作为变量,执行mongodb的修改

  4.notepad++ 软件

三、解决步骤:

  1.需要将execl格式的人员名单取出放入自己设定的列表中(如arr = [" ", " " ]):

    1.1.选取所需的列数据,复制后,粘贴到新建excel表格中;  # 特别注意:粘贴时,应选择第一个单元格,然后右击,在弹出的窗口中,选择‘选择性粘贴’,再选择‘转置'mongodb使用_遍历列表中的元素,作为变量,循环修改mongodb中的字段

 

     1.2.将排成一行的数据另存到桌面上,保存类型选择csv(逗号分隔),后续弹出的窗口一直选是(可能会说不兼容什么的,不管,关闭时弹出的窗口也选是)

mongodb使用_遍历列表中的元素,作为变量,循环修改mongodb中的字段

 

    1.3.给csv文件中的数据添加单/双引号: 右键点击桌面上的csv文件,选择“edit with notepad++"打开,

      ctrl+h -> 勾上正则 -> 查找逗号:, -> 替换成:",";

      ctrl+h -> 勾上正则 -> 查找行头:^ -> 替换成:";

      ctrl+h -> 勾上正则 -> 查找行尾:$ -> 替换成:";(第三步可能是多余的)

    1.4.复制处理完成后的数据,放入列表中,即:arr = ["zhangsan","lisi"]

  2.进入nosqlbooster for mongodb中,选择需要修改的数据所在的库和表,输入以下语句,即可更新人员状态:

    var arr = ["zhangsan","lisi"];
    for (var i=0; i<arr.length; i++){
        db.user.update({"code": arr[i]}, {"$set": {"status" : "invalid", "memo" : "离职"}});  # user、 "status"、"memo"为数据库对应的表名、人员状态、备注的字段名
    }

mongodb使用_遍历列表中的元素,作为变量,循环修改mongodb中的字段

 mongodb使用_遍历列表中的元素,作为变量,循环修改mongodb中的字段

 

 四、所用到的技巧/技术,以及参考链接:

   1.excel数据转为带双引号的数据: https://www.phpfans.net/ask/quiz1/92901015155.html

   2.mongdb的循环修改(笔者修改的不是一条语句中的多个相同值,而是多条语句中的一个值):https://www.jianshu.com/p/1f02dcba779c  

    # 若想修改的一条语句中的多个相同值,可参考https://blog.csdn.net/xc_zhou/article/details/80994787或https://blog.csdn.net/jsdxshi/article/details/72841283