MongoDB——索引操作

46 阅读2分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 10 月更文挑战」的第11天,点击查看活动详情

创建索引

语法格式:

db.<collection>.createIndex( <key and index type specification>, <options> )
  • collection:集合
  • key:字段
  • index:一般情况,1升序,-1降序,但是还有一个特殊索引,比如全文索引,哈希索引
  • options:可选参数
ParameterTypeDescription
backgroundBoolean建索引过程会阻塞其它数据库操作, background可指定 以后台方式创建索引, 即增加 "background" 可选参 数。 "background" 默认值为false。
uniqueBoolean建立的索引是否唯一。指定为true创建唯一索引。默认值 为false.
namestring索引的名称。如果未指定, MongoDB的通过连接索引的 字段名和排序顺序生成一个索引名称。
dropDupsBoolean3.0 +版本已废弃。在建立唯一索引时是否删除重复记录, 指定 true 创建唯一索引。默认值为 false.
sparseBoolean对文档中不存在的字段数据不启用索引; 这个参数需要特 别注意, 如果设置为true的话, 在索引字段中不会查询出 不包含对应字段的文档。默认值为 false.
expireAfterSecondsinteger指定一个以秒为单位的数值, 完成 TTL设定, 设定集合的 生存时间。
vindex version索引的版本号。默认的索引版本取决于mongod创建索引 时运行的版本。
weightsdocument索引权重值, 数值在 1 到 99,999 之间, 表示该索引相对 于其他索引字段的得分权重。
default_languagestring对于文本索引, 该参数决定了停用词及词干和词器的规则 的列表。 默认为英语
language_overridestring对于文本索引, 该参数指定了包含在文档中的字段名, 语言覆盖默认的language, 默认值为 language.

查看索引

查看索引信息

db.<collection>.getIndexes()

查看索引键

db.<collection>.getIndexKeys()

查看索引占用空间

db.<collection>.totalIndexSize([is_detail])
  • is_detail:可选参数,0或false表示查看所有索引总大小,列出所有索引占用空间

删除索引

删除集合内指定索引

db.<collection>.dropIndex("索引名称")

删除集合内所有索引

db.<collection>.dropIndexes()