mongodb使用_遍歷列表中的元素,作為變數,迴圈修改mongodb中的欄位

来源:https://www.cnblogs.com/wangxue533/archive/2019/11/26/11935537.html

一、問題描述: 需要將工作界面上的一些已經離職的用戶狀態改為失效,並備註為離職 二、需要準備/拿到手的工具/條件/數據: 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表格中;  # 特別註意:粘貼時,應選擇第一個單元格,然後右擊,在彈出的視窗中,選擇‘選擇性粘貼’,再選擇‘轉置'

 

     1.2.將排成一行的數據另存到桌面上,保存類型選擇csv(逗號分隔),後續彈出的視窗一直選是(可能會說不相容什麼的,不管,關閉時彈出的視窗也選是)

 

    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"為資料庫對應的表名、人員狀態、備註的欄位名
    }

 

 

 四、所用到的技巧/技術,以及參考鏈接:

   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


您的分享是我們最大的動力!

更多相關文章
  • 卸載系統自帶的jdk 1. 查詢系統是否已經安裝了jdk rpm -qa|grep java 2. 卸載已安裝的jdk, 系統可能會自帶多個jdk版本, 按需卸載 rpm -e --nodeps java-1.7.0-openjdk-1.7.0.141-2.6.10.5.el7.x86_64 3.  ...
  • https://sqlserver.code.blog/2019/11/26/missing-msi-and-msp-files/ ...
  • 預讀:用估計信息,去硬碟讀取數據到緩存。預讀100次,也就是估計將要從硬碟中讀取了100頁數據到緩存。 物理讀:查詢計劃生成好以後,如果緩存缺少所需要的數據,讓緩存再次去讀硬碟。物理讀10頁,從硬碟中讀取10頁數據到緩存。 邏輯讀:從緩存中取出所有數據。邏輯讀100次,也就是從緩存里取到100頁數據 ...
  • bitmap就是在一個二進位的數據中,每一個位代表一定的含義,這樣最終只需要存一個整型數據,就可以解釋出多個含義.業務中有一個欄位專門用來存儲用戶對某些功能的開啟和關閉,如果是傳統的思維,肯定是建一個欄位來存0代表關閉,1代表開啟,那麼如果功能很多或者需要加功能開關,就需要不停的創建欄位.使用bit ...
  • 背 景: 在MySQL中如果是有限的層次,比如我們事先如果可以確定這個樹的最大深度, 那麼所有節點為根的樹的深度均不會超過樹的最大深度,則我們可以直接通過left join來實現。 但很多時候我們是無法控制或者是知道樹的深度的。這時就需要在MySQL中用存儲過程(函數)來實現或者在程式中使用遞歸來實 ...
  • select A.* from tb_mend_enrol A, (select A.Typeid, A.address from tb_mend_enrol A group by A.Typeid, A.address having count(A.Typeid) >= 2 and count(A ...
  • [20191126]探究等待事件的本源2.txt--//做一個測試,驗證如果寫入控制文件慢也會影響提交性能.1.環境:[email protected]> @ ver1PORT_STRING VERSION BANNER x86_64/Linux 2.4.xx 11.2.0.4.0 Oracle Database ...
  • -- 1.提取此類數據中的1的索引位置,從1開始 例: 0001100001100 --> 4,5,10,11 create or replace function hazq_instr_contains( v_str in varchar2)return varchar2is v_count nu ...
一周排行
  • 比如要拆分“呵呵呵90909086676喝喝999”,下麵當type=0返回的是中文字元串“呵呵呵,喝喝”,type=1返回的是數字字元串“90909086676,999”, private string GetStrings(string str,int type=0) { IList<strin ...
  • Swagger一個優秀的Api介面文檔生成工具。Swagger可以可以動態生成Api介面文檔,有效的降低前後端人員關於Api介面的溝通成本,促進項目高效開發。 1、使用NuGet安裝最新的包:Swashbuckle.AspNetCore。 2、編輯項目文件(NetCoreTemplate.Web.c ...
  • 2020 年 7 月 30 日, 由.NET基金會和微軟 將舉辦一個線上和為期一天的活動,包括 微軟 .NET 團隊的演講者以及社區的演講者。本次線上大會 專註.NET框架構建微服務,演講者分享構建和部署雲原生應用程式的最佳實踐、模式、提示和技巧。有關更多信息和隨時瞭解情況:https://focu... ...
  • #abp框架Excel導出——基於vue #1.技術棧 ##1.1 前端採用vue,官方提供 UI套件用的是iview ##1.2 後臺是abp——aspnetboilerplate 即abp v1,https://github.com/aspnetboilerplate/aspnetboilerp ...
  • 前言 本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。 作者:碧茂大數據 PS:如有需要Python學習資料的小伙伴可以加下方的群去找免費管理員領取 input()輸入 Python提供了 input() 內置函數從標準輸入讀入一 ...
  • 從12年到20年,python以肉眼可見的趨勢超過了java,成為了當今It界人人皆知的編程語言。 python為什麼這麼火? 網路編程語言搜索指數 適合初學者 Python具有語法簡單、語句清晰的特點,這就讓初學者在學習階段可以把精力集中在編程對象和思維方法上。 大佬都在用 Google,YouT ...
  • 在社會上存在一種普遍的對培訓機構的學生一種歧視的現象,具體表現在,比如:當你去公司面試的時候,一旦你說了你是培訓機構出來的,那麼基本上你就涼了,那麼你瞞著不說,然後又通過了面試成功入職,但是以後一旦在公司被髮現有培訓經歷,可能會面臨被降薪,甚至被辭退,培訓機構出來的學生,在用人單位眼裡就是能力低下的 ...
  • from typing import List# 這道題看了大佬寫的代碼,經過自己的理解寫出來了。# 從最外圍的四周找有沒有為O的,如果有的話就進入深搜函數,然後深搜遍歷# 判斷上下左右的位置是否為Oclass Solution: def solve(self, board: List[List[s ...
  • import requests; import re; import os; # 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537.36 (KHTML, li ...
  • import requests; import re; import os; import parsel; 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537. ...