Mongodb索引使用限制

學習mongodb,體會mongodb的每一個使用細節,歡迎閱讀威贊的文章。這是威贊發布的第85篇mongodb技術文章,歡迎瀏覽本專欄威贊發布的其他文章。如果您認為我的文章對您有幫助或者解決您的問題,歡迎在文章下面點個贊,或者關注威贊。謝謝。

通過在Mongodb添加索引,能夠提高Mongodb查詢效率。但在索引在使用當中也會有一些限制。本文結合官方文檔,介紹Mongodb索引使用上的一些限制。

每個集合的索引數量

單個集合當中,最多可以添加64個索引

復合索引字段數量

復合索引當中,最多包含32個字段

特殊索引查詢

用戶不可以將文本查詢$text中創建的索引與另外一種特殊類型的索引共同使用。如用戶不能夠共同使用$text查詢和$near操作符。

二維空間索引僅能包含地理信息數據

帶有二維空間索引的字段必須保存GeoJSON數據類型或者坐標值。如果用戶向二維空間索引字段插入其他類型的數據,或向包含其他數據類型的字段建立二維空間索引時,mongodb會報錯。

二維空間索引鍵數量限制

為了生成二維空間索引,mongodb將GeoJSON類型的數據匹配到mongodb內部的一種數據展現方式。這種數據匹配過程可能會生成一個特別大的數組。

而當mongodb為數組字段創建索引時,mongdb會為每一個數據元素創建一個索引鍵。對于復合索引,mongod計算為每個字段生成的鍵集的笛卡爾乘積。構建笛卡爾乘積的兩個數據集特別大時,數據計算的過程中可能會超過mongodb的內存限制。為了保證mongodb不會出現內存限制問題,mongodb使用參數indexMaxNumGeneratedKeysPerDocument 限制單個文檔生成索引時最大鍵的數量。默認值是100000.當構建索引時,超過這個限制數量,mongodb會報錯。

NaN值的處理

在索引覆蓋查詢中,使用WiredTiger引擎時,NaN的數字類型是double

多鍵索引

多鍵索引不能覆蓋不在相同數組的字段。

地理信息索引

地理信息索引不支持索引覆蓋查詢

索引構建時的內存使用

createIndexes方法支持在一個集合中建立一個或多個索引。這個方法在構建索引時結合使用內存和臨時文件。默認分配200Mb內存給createIndexes方法。當createIndexes方法創建多個索引時,構建多個索引過程中共用這200Mb的空間。當默認分配的創建索引內存空間被占滿是,mongodb使用臨時文件來繼續構建索引。這些臨時文件保存在--dbpath參數配置的路徑下的_tmp文件夾當中。用戶可以通過指定參數 maxIndexBuildMemoryUsageMegabytes 來修改這個默認的索引構建內存。分配更大的內存,會提高索引的構建效率。但過高的內存分配,可能會導致操作系統的內存使用過多,甚至服務重啟。

用戶通過createIndexes方法或者使用數據庫管理中的數據初始同步命令時,都會觸發索引構建。這些索引構建需要的內存大小,都是由參數maxIndexBuildMemoryUsageMegabytes指定的。單個集合的數據初始同步,沒有什么內存使用風險。但用戶很有可能同時觸發多個數據庫的數據初始同步,這樣的同步操作內存使用很有可能超過限制。

字符序和索引類型

文本索引和二維索引斤支持簡單的二進制比較,不支持字符序。

隱藏索引

用戶不可以隱藏默認的_id字段索引

用戶不可以在hint()方法中使用隱藏索引

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

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

相關文章

Sahi+Yolov10

一、前言 了解到Sahi,是通過切圖,實現提高小目標的檢測效果。sahi 目前支持yolo5\yolo8\mmdet\detection2 等等算法,本篇主要通過實驗onnx加載模型的方式使sahi支持yolov10。 二、代碼 (1)轉換模型 首先使用 conda創…

大數的排列組合公式C代碼

我們知道,計算排列A(n,m)和組合C(n,m)可以用先求階乘的方式實現,但是當數很大時求階乘很容易溢出,所以這里給出非階乘的方式求排列組合 求排列 分母和分子可以抵消,最后代碼如下 unsigned long long A(int n, int m) {unsigned…

華為機試HJ34圖片整理

華為機試HJ34圖片整理 題目: 想法: 將輸入的字符串中每個字符都轉為ASCII碼,再通過快速排序進行排序并輸出 input_str input() input_list [int(ord(l)) for l in input_str]def partition(arr, low, high):i low - 1pivot arr[high]f…

RPC與REST

RPC與REST 訪問遠程服務1遠程服務調用(Remote Procedure Call,RPC):RPC 解決什么問題?如何解決的?為什么要那樣解決?1.1 先解決兩個進程間如何交換數據的問題,也就是進程間通信&…

最新扣子(Coze)實戰案例:使用擴圖功能,讓你的圖任意變換,完全免費教程

🧙?♂? 大家好,我是斜杠君,手把手教你搭建扣子AI應用。 📜 本教程是《AI應用開發系列教程之扣子(Coze)實戰教程》,完全免費學習。 👀 微信關注公從號:斜杠君,可獲取完整版教程。&a…

如何快速搭建python項目的虛擬環境

itopen組織1、提供OpenHarmony優雅實用的小工具2、手把手適配riscv qemu linux的三方庫移植3、未來計劃riscv qemu ohos的三方庫移植 小程序開發4、一切擁抱開源,擁抱國產化 你在開發python工具的時候還一直使用系統默認的環境嗎?是否有遇到有時候…

2024年【北京市安全員-B證】報名考試及北京市安全員-B證最新解析

題庫來源:安全生產模擬考試一點通公眾號小程序 2024年北京市安全員-B證報名考試為正在備考北京市安全員-B證操作證的學員準備的理論考試專題,每個月更新的北京市安全員-B證最新解析祝您順利通過北京市安全員-B證考試。 1、【多選題】《中華人民共和國安…

android輪播圖入門2——觸摸停止與指示器

前言 這次要在上一篇輪播圖的基礎上做改造,增加兩個功能: 用戶觸摸到輪播圖時,停止輪播在輪播圖上展示一個小指示器,指示當前輪播組件的位置 觸摸停播 觸摸停播的設計思路是:監聽實現輪播圖的觸摸事件,…

手把手教你從零開始構建 AI 視頻生成模型

在 GitHub 上發現一篇教程,作者詳細介紹了如何使用 Python 語言,從零開始構建一個文本到視頻生成模型。 涵蓋了從理解理論概念到架構編碼,最終實現輸入文本提示即可生成視頻的全過程。 相關鏈接 GitHub:github.com/FareedKhan-…

python-redis-lock是如何實現鎖自動續期的

python-redis-lock簡介 python-redis-lock是一個python的第三方庫,基于Redis,封裝了分布式鎖的邏輯,提供了更高級的API來簡化鎖的獲取、保持和釋放過程。包括自動續期、鎖超時、重入鎖等功能。 相比于直接使用redis的setnx,避免了…

倒退型自閉癥與輕度自閉癥有什么區別?

作為星貝育園自閉癥兒童康復中心的一名專業教師,我深知家長們在面對自閉癥譜系障礙(ASD)時的種種疑問與挑戰,尤其是關于倒退型自閉癥與輕度自閉癥之間的區別。今天,我將從專業視角出發,深入淺出地解析這兩種…

精通Vim編輯器:Linux系統下的強大文本編輯工具

精通Vim編輯器:Linux系統下的強大文本編輯工具 引言 在Linux世界中,Vim是一個功能強大、高度可定制的文本編輯器,它繼承自經典的vi編輯器并提供了一系列增強功能。無論是系統管理員、開發人員還是普通用戶,掌握Vim的使用都能大幅…

游戲AI的創造思路-技術基礎-強化學習(2)

上一篇中引出了深度強化學習這個大坑,本篇淺淺填一下~~~~ 目錄 6. 深度強化學習概述 6.1. 基本概念 6.2. 發展歷史 6.3. 基本公式 6.4. Python實現 6.5. 運行原理 6.5.1. 核心要素 6.5.2. 運行原理 6.5.3. 典型算法 6.5.4. Python實現代碼 6.6. 優缺點 …

Segmentation fault (core dumped)

錯誤簡介 出現 “Segmentation fault (core dumped)” 錯誤通常意味著程序訪問了未分配的內存或者越界訪問了已分配內存之外的區域。 段錯誤通常發生在以下情況: 空指針解引用:嘗試對空指針進行操作。內存越界:訪問了超出分配內存邊界的區…

大廠面試官贊不絕口的后端技術亮點【后端項目亮點合集(2)】

本文將持續更新~~ hello hello~ ,這里是絕命Coding——老白~💖💖 ,歡迎大家點贊🥳🥳關注💥💥收藏🌹🌹🌹 💥個人主頁:絕命C…

提高論文發表機會:Nature Communications 最新研究教你如何巧妙回復審稿意見

我是娜姐 迪娜學姐 ,一個SCI醫學期刊編輯,探索用AI工具提效論文寫作和發表。 對于科研搬磚人來說,在論文投稿過程中,如何有效回復審稿意見才能得到審稿人的認可,一直是一個讓人困惑又帶點玄學的問題。 但是&#xff0c…

vue3 按鈕復制粘貼功能

1.html <div click"copy(item.envelopePassword)" > 復制口令 </div> 2.utils 創建copy.js export const copy (val: string): void > {let { isSuccessRef } useCopyToClipboard(val) as anyif (isSuccessRef) {// 輕提示showNotify("復制…

【強化學習的數學原理】課程筆記--3(蒙特卡洛方法)

目錄 蒙特卡洛方法MC Basic算法sparse reward MC Greedy 算法樣本使用效率MC ? \epsilon ?-Greedy 算法一些例子 蒙特卡洛方法 第二節 推導貝爾曼最優公式中的&#xff1a; q π k ( s , a ) ∑ r P ( r ∣ s , a ) r γ ∑ s ′ P ( s ′ ∣ s , a ) v π k ( s ′ ) q…

vue3 ~ pinia學習

先看兩個圖 一個vuex 一個pinia 根據圖看出來 pinia更簡單了 那么具體怎么操作呢 我們來看下~ 第一步 下載 yarn add pinia # 或者使用 npm npm install pinia 第二步 注冊 創建一個 pinia 實例 (根 store) 并將其傳遞給應用&#xff1a; import { createApp } from v…

代碼隨想錄算法訓練Day57|LeetCode200-島嶼數量、LeetCode695-島嶼的最大面積

島嶼數量 題目描述 力扣200-島嶼數量 給你一個由 1&#xff08;陸地&#xff09;和 0&#xff08;水&#xff09;組成的的二維網格&#xff0c;請你計算網格中島嶼的數量。 島嶼總是被水包圍&#xff0c;并且每座島嶼只能由水平方向和/或豎直方向上相鄰的陸地連接形成。 此…