MongoDB 常用操作指南(Docker 環境下)

本文詳細介紹如何在 Docker 中操作 MongoDB,包括如何進入命令行、進行用戶認證、查看數據庫和集合,以及常用的索引操作和其他高頻使用的 MongoDB 方法。小白也能輕松上手


1. 在 Docker 中進入 MongoDB 命令行

  1. 進入運行 MongoDB 容器的命令行:

    docker exec -it <容器名稱或ID> mongo
    

    例如:

    docker exec -it mongodb_container mongo
    
  2. 切換到管理員數據庫 admin

    use admin
    
  3. 用戶認證:

    db.auth("aidenmx", "qazx123")
    db.auth("aiden", "qazx123")
    

    提示:這里假設您的用戶名為 aidenmxaiden,密碼為 qazx123。根據實際情況替換。通常只需一次認證。


2. 查看數據庫和集合

  1. 顯示所有數據庫:

    show dbs
    
  2. 切換到某個數據庫:

    use history
    
  3. 顯示當前數據庫的所有集合(表):

    show tables
    

3. 查看集合中的索引

查看指定集合中的索引信息:

db.<集合名>.getIndexes()

例如:

db.sublist2.getIndexes()

輸出會顯示所有索引的詳細信息,包括索引字段和索引類型。


4. 創建索引

4.1 創建單字段索引

為某個字段創建索引:

db.<集合名>.createIndex({ <字段名>: 1 })
  • 1 表示升序索引,-1 表示降序索引。

例如:

db.sublist2.createIndex({ applicationNumber: 1 })

4.2 創建復合索引

為多個字段創建復合索引:

db.<集合名>.createIndex({ <字段1>: 1, <字段2>: -1 })
  • 注意字段順序,前綴規則適用。

例如:

db.sublist2.createIndex({ applicationNumber: 1, classNumber: -1 })

5. 刪除索引

  1. 刪除單個索引:

    db.<集合名>.dropIndex("<索引名>")
    

    獲取索引名可通過 getIndexes() 查看。

  2. 刪除集合中的所有索引:

    db.<集合名>.dropIndexes()
    

6. 查詢相關操作

  1. 查詢所有文檔:

    db.<集合名>.find()
    
  2. 查詢第一個文檔:

    db.<集合名>.findOne()
    
  3. 條件查詢:

    db.<集合名>.find({ <字段名>: <> })
    

    例如:

    db.sublist2.find({ applicationNumber: "123456" })
    
  4. 限制返回條數:

    db.<集合名>.find().limit(10)
    
  5. 排序查詢:

    db.<集合名>.find().sort({ <字段名>: 1 })
    
    • 1 表示升序,-1 表示降序。

7. 插入與刪除操作

  1. 插入單個文檔:

    db.<集合名>.insertOne({ <字段1>: <1>, <字段2>: <2> })
    

    例如:

    db.sublist2.insertOne({ applicationNumber: "123456", classNumber: 5 })
    
  2. 刪除符合條件的文檔:

    db.<集合名>.deleteOne({ <字段名>: <> })
    

    例如:

    db.sublist2.deleteOne({ applicationNumber: "123456" })
    
  3. 刪除所有文檔:

    db.<集合名>.deleteMany({})
    

8. 更新操作

  1. 更新單個文檔:

    db.<集合名>.updateOne({ <匹配條件> },{ $set: { <字段1>: <新值1>, <字段2>: <新值2> } }
    )
    

    例如:

    db.sublist2.updateOne({ applicationNumber: "123456" },{ $set: { classNumber: 10 } }
    )
    
  2. 更新多個文檔:

    db.<集合名>.updateMany({ <匹配條件> },{ $set: { <字段1>: <新值1>, <字段2>: <新值2> } }
    )
    

9. 數據統計

  1. 查看集合中文檔數量:

    db.<集合名>.countDocuments()
    
  2. 按條件統計文檔數量:

    db.<集合名>.countDocuments({ <字段名>: <> })
    

    例如:

    db.sublist2.countDocuments({ classNumber: 5 })
    

通過上述命令,您可以高效地操作 MongoDB 數據庫。直接復制粘貼使用即可!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/63916.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/63916.shtml
英文地址,請注明出處:http://en.pswp.cn/web/63916.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【Java基礎面試題038】棧和隊列在Java中的區別是什么?

回答重點 棧&#xff08;Stack&#xff09;&#xff1a;遵循后進先出&#xff08;LIFO&#xff0c;Last In&#xff0c;First Out&#xff09;原則。即&#xff0c;最后插入的元素最先被移除。主要操作包括push&#xff08;入棧&#xff09;和pop&#xff08;出棧&#xff09;…

idea2024創建JavaWeb項目以及配置Tomcat詳解

今天呢&#xff0c;博主的學習進度也是步入了JavaWeb&#xff0c;目前正在逐步楊帆旗航&#xff0c;迎接全新的狂潮海浪。 那么接下來就給大家出一期有關JavaWeb的配置教學&#xff0c;希望能對大家有所幫助&#xff0c;也特別歡迎大家指點不足之處&#xff0c;小生很樂意接受正…

由于這些關鍵原因,我總是手邊有一臺虛擬機

概括 虛擬機提供了一個安全的環境來測試有風險的設置或軟件,而不會影響您的主系統。設置和保存虛擬機非常簡單,無需更改主要設備即可方便地訪問多個操作系統。運行虛擬機可能會占用大量資源,但現代 PC 可以很好地處理它,為實驗和工作流程優化提供無限的可能性。如果您喜歡使…

【FPGA】ISE13.4操作手冊,新建工程示例

關注作者了解更多 我的其他CSDN專欄 求職面試 大學英語 過程控制系統 工程測試技術 虛擬儀器技術 可編程控制器 工業現場總線 數字圖像處理 智能控制 傳感器技術 嵌入式系統 復變函數與積分變換 單片機原理 線性代數 大學物理 熱工與工程流體力學 數字信號處…

python環境中阻止相關庫的自動更新

找到conda中的Python虛擬環境位置 這里以conda中的pytorch虛擬環境為例&#xff08;Python環境位置&#xff09;&#xff0c;在.conda下的envs中進入pytorch下的conda-meta路徑下 新建一個空白的pinned文檔 右鍵點擊桌面或文件資源管理器中的空白處&#xff0c;選擇“新建” …

重溫設計模式--外觀模式

文章目錄 外觀模式&#xff08;Facade Pattern&#xff09;概述定義 外觀模式UML圖作用 外觀模式的結構C 代碼示例1C代碼示例2總結 外觀模式&#xff08;Facade Pattern&#xff09;概述 定義 外觀模式是一種結構型設計模式&#xff0c;它為子系統中的一組接口提供了一個統一…

uniapp 微信小程序 頁面部分截圖實現

uniapp 微信小程序 頁面部分截圖實現 ? 原理都是將頁面元素畫成canvas 然后將canvas轉化為圖片&#xff0c;問題是我頁面里邊本來就有一個canvas&#xff0c;ucharts圖畫的canvas我無法畫出這塊。 ? 想了一晚上&#xff0c;既然canvas最后能轉化為圖片&#xff0c;那我直接…

Flutter 基礎知識總結

1、Flutter 介紹與環境安裝 為什么選擇 Dart&#xff1a; 基于 JIT 快速開發周期&#xff1a;Flutter 在開發階段采用 JIT 模式&#xff0c;避免每次改動都進行編譯&#xff0c;極大的節省了開發時間基于 AOT 發布包&#xff1a;Flutter 在發布時可以通過 AOT 生成高效的 ARM…

Jenkins 持續集成部署

Jenkins的安裝與部署 前言 當我們在實施一個項目時&#xff0c;從新代碼中獲得反饋的速度越快&#xff0c;問題越早得到解決&#xff0c;獲得反饋的一種常見方法是在新代碼之后運行測試&#xff0c;但這就導致了當代碼正在編譯并且正在運行測試時&#xff0c;開發人員無法在測…

跨站請求偽造之基本介紹

一.基本概念 1.定義 跨站請求偽造&#xff08;Cross - Site Request Forgery&#xff0c;縮寫為 CSRF&#xff09;漏洞是一種網絡安全漏洞。它是指攻擊者通過誘導用戶訪問一個惡意網站&#xff0c;利用用戶在被信任網站&#xff08;如銀行網站、社交網站等&#xff09;的登錄狀…

Pytorch | 利用BIM/I-FGSM針對CIFAR10上的ResNet分類器進行對抗攻擊

Pytorch | 利用BIM/I-FGSM針對CIFAR10上的ResNet分類器進行對抗攻擊 CIFAR數據集BIM介紹基本原理算法流程 BIM代碼實現BIM算法實現攻擊效果 代碼匯總bim.pytrain.pyadvtest.py 之前已經針對CIFAR10訓練了多種分類器&#xff1a; Pytorch | 從零構建AlexNet對CIFAR10進行分類 Py…

如何更好的進行時間管理

先想一下我們想要做的事情&#xff0c;然后拿出Excel表格將這些事情記錄下來&#xff0c;我們把它叫做任務對這些任務按照重要性&#xff0c;緊急程度進行排序&#xff0c;拿出表格中的前六個任務&#xff0c;就是今天要做的任務新建另一張excel表格&#xff0c;表格的一列為時…

OpenGL —— 2.6.1、繪制一個正方體并貼圖渲染顏色(附源碼,glfw+glad)

源碼效果 C++源碼 紋理圖片 需下載stb_image.h這個解碼圖片的庫,該庫只有一個頭文件。 具體代碼: vertexShader.glsl #version

ubuntu開機進入initramfs狀態

虛擬機卡死成功起后進入了initramfs狀態&#xff0c;可能是跟文件系統有問題或者檢索不到根文件系統&#xff0c;或者是配置錯誤&#xff0c;系統磁盤等硬件問題導致 開機后進入如下圖的界面&#xff0c; 文中有一條提示 要手動fsck 命令修復 /dev/sda1 命令如下 fsck /de…

java根據Word模板實現動態填充導出

最近項目中需要導出Word&#xff0c;根據不同的信息導出不同的內容&#xff0c;包含文本、列表、圖片等&#xff0c;本文使用poi-tl實現在次做以記錄。 添加依賴 <!-- word導出 --> <dependency><groupId>com.deepoove</groupId><artifactId>po…

mindie推理大語言模型問題及解決方法匯總

問題說明 使用功能mindie 1.0 RC2推理大語言模型&#xff0c;遇到不少問題&#xff0c;記錄下解決思路。 我的硬件是910B4。 問題及解決 問題1 在docker內啟動mindie時終端報錯 Fatal Python error: PyThreadState_Get: the function must be called with the GIL held, …

Selenium 全面指南

Selenium 是一個強大的 Web 自動化工具&#xff0c;支持多種瀏覽器和語言綁定。 1. Selenium 的基本概念 WebDriver&#xff1a;Selenium 提供的核心接口&#xff0c;用于控制瀏覽器操作。顯式等待&#xff1a;等待特定條件滿足后再執行操作。隱式等待&#xff1a;全局設置一個…

Go框架比較:goframe、beego、iris和gin

由于工作需要&#xff0c;這些年來也接觸了不少的開發框架&#xff0c;Golang的開發框架比較多&#xff0c;不過基本都是Web"框架"為主。這里稍微打了個引號&#xff0c;因為大部分"框架"從設計和功能定位上來講&#xff0c;充其量都只能算是一個組件&…

【華為OD-E卷-木板 100分(python、java、c++、js、c)】

【華為OD-E卷-木板 100分&#xff08;python、java、c、js、c&#xff09;】 題目 小明有 n 塊木板&#xff0c;第 i ( 1 ≤ i ≤ n ) 塊木板長度為 ai。 小明買了一塊長度為 m 的木料&#xff0c;這塊木料可以切割成任意塊&#xff0c;拼接到已有的木板上&#xff0c;用來加…

sqlserver臨時表來做表聯查復雜查詢

使用臨時表&#xff0c;先查詢出結果&#xff0c;在用于后面表的子查詢或者聯查 -- 刪除表1if EXISTS ( SELECT 1 FROM tempdb.sys.objects where name like #temp_PublishRecord% ) beginDROP TABLE #temp_PublishRecordprint 已刪除臨時表 #temp_PublishRecordend--創…