- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章关于对MongoDB索引的一些简单理解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
索引可以提升文档的查询速度,但建立索引的过程需要使用计算与存储资源,在已经建立索引的前提下,插入新的文档会引起索引顺序的重排.
MongoDB 的索引是基于 B-tree 数据结构及对应算法形成的。树索引存储特定字段或字段集的值,按字段值排序。索引条目的排序支持有效的等式匹配和基于范围的查询操作.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
{
"_id" : ObjectId("6127594238754d0067383ff6"),
"xh" : 1,
"szly" : {
"lymc" : "AA大厦",
"z" : "A",
"lh" : "1",
"sy" : "啥意思"
},
"qtxx" : {
"nsssjg" : "A、区内",
"sfwkgh" : "否",
"cylx" : "第三产业",
"rzlysj" : "2011.11",
"fwcqdw" : "河南置业有限公司",
"fwszlc" : "5",
"fjh" : "601、604",
"mj" : 56,
"cyry" : 5,
"yzj" : 2,
"qylx" : "H、其他",
"ssqylx" : "C、非上市企业",
"lxr" : "AA兰",
"lxdh" : "85685685"
},
"sssq" : "裕鸿楼宇社区",
"frxx" : {
"qyfr" : "AA兰",
"qyfzr" : "AA兰",
"lxfs" : "18888888888"
},
"qyjbxx" : {
"xy" : "P 教育",
"qymc" : "郑州市管城回族培训学校",
"gsyyzzh" : "31313123",
"swdjzh" : "123123123",
"tyxydm" : "313123123",
"zcdz" : "裕鸿国际A座6层",
"jjxz" : "有限责任公司",
"zczb" : 100
},
"importMonth" : "202108",
"batch" : "1629968706400_1",
"createBy" : "1",
"department" : "区政府",
"createTime" : ISODate("2021-08-26T09:05:06.416Z"),
"status" : 0,
"ddly" : {
"zh" : "",
"lh" : "",
"sy" : ""
},
"lcxx" : {
"zb" : "",
"szlc" : "",
"mj" : ""
},
"updateBy" : "1",
"updateTime" : "2021-08-27 11:14:31"
}
|
默认索引:_id(唯一性的索引) 。
唯一索引会保证索引对应的键不会出现相同的值,如果唯一索引所在的字段有重复数据写入时,抛出异常.
1
|
db.getCollection(
"qydrmb_copy"
).createIndex({
"qtjbxx"
:1},{
unique
:
true
})
|
最普通索引,不会自动创建.
创建单建索引示例 。
1
2
3
|
db.getCollection(
"qydrmb_copy"
).createIndex({
"qtjbxx"
:1})
db.getCollection(
"qydrmb_copy"
).createIndex({
"qtxx.fwcqdw"
:1})
|
注意:
多键索引和单键索引创建形式一样,区别:字段的值,值具有多个记录,如,数组 。
注意:通过 getIndexes() 不能区分该索引是单键索引还是多键索引,可以 explain() 执行计划的打印信息中查看(isMultKey 属性) 。
复合索引针对多个字段联合创建索引,先按照第一个字段排序,第一个字段相同的文档按照第二个字段排序,依次类推.
语法:
db.collection_name.createIndex({索引键名:排序规则, 索引键名:排序规则, ...}) 。
复合索引能满足的查询场景比单字段索引更丰富,不光能满足多个字段组合起来的查询,也能满足所有能匹配符合索引前缀的查询.
注意:创建一个复合索引 A、B, 查询条件中包含A,B会走索引,查询条件中包含A,也会走索引,查询条件中没有A,只有一个B,此时不会走索引。A就称为索引前缀.
交叉索引就是为了一个集合的多个字段分别建立索引,在查询的时候通过多个字段作为查询条件,这种情况称为交叉索引.
交叉索引和复合索引区别:交叉索引 A、B是两个索引,复合索引中 A、B组成了一个索引.
注意:一个集合中包含交叉索引A、 B,在查询条件中包含A、或者包含B、或者包含A、B的情况下,都会触发交叉索引.
部分索引是针对符合某个特定条件的文档建立索引,3.2版本才支持该特性.
MongoDB 部分索引只为那些在一个集合中,满足指定的筛选条件的文档创建索引。简单理解就是部分索引是带有过滤条件的索引,即索引只存在于某些文档之上 。
语法:
db.collection_name.createIndex({索引键名:排序规则},{partialFilterExpression:{"前面进行排序的键名":{匹配条件:条件值}}}) 。
注意:部分索引和唯一所以一块使用,唯一约束只适用于满足筛选条件的文档.
1.所有的查询字段是索引的一部分 。
2.查询返回的所有字段在同一个索引中 。
例如:如果一个索引中包含A、B 两个字段,查询条件只有一个A, 返回结果为 A、B两个字段,则此时会触发覆盖索引,即不再扫描整个文档,而是直接从索引中获取数据.
全文检索对每一个词建立一个索引,指明该词在文章中出现的次数和位置,当用户查询时,检索程序就根据事先建立的索引进行查找,并将查找的结果反馈给用户的检索方式.
MongoDB 从 2.4 版本开始支持全文检索,目前支持15种语言的全文索引(danish、dutch、english、finnish、french、german、hungarian、italian、norwegian、portuguese、romanian、russian、spanish、swedish、turkish).
mongo2.6之后默认开启全文检索.
创建语法:
db.collection_name.ensureIndex({全文索引的字段名:"text"}) 。
查询语法:
db.collection_name.find({$text:{$search:"检索的值"}}) 。
到此这篇关于对MongoDB索引的一些简单理解的文章就介绍到这了,更多相关MongoDB索引简单理解内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://www.cnblogs.com/wgx519/p/15268943.html 。
最后此篇关于关于对MongoDB索引的一些简单理解的文章就讲到这里了,如果你想了解更多关于关于对MongoDB索引的一些简单理解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
这几天我一直在努力。我一直在自学 CSS,所以对菜鸟好一点。我正在创建一个推荐 slider 。推荐以 3 个 block 显示。我希望前 2 个下降,第 3 个上升。但是当 slider 激活时,无
我最近开始学习 Nodejs,现在我很困惑我的网络应用程序使用什么,html 还是 ejs (Express)。 Ejs 使用 Express 模块,而 .html 使用 HTML 模块。我的第一个问
假设我们有一个 PostgreSQL 表contacts,每条记录都有一堆带标签的电子邮件地址(标签和电子邮件对)——其中一个是“主要”。 存储方式如下: id 主键 电子邮件 文本 email_la
我成功为一种新的tesseract语言编写了traineddata文件,但是当我完成时,我继续收到以下错误: index >= 0 && index = 0 && 索引 < size_used_ :E
这个问题已经有答案了: How to deal with SettingWithCopyWarning in Pandas (21 个回答) 已关闭 4 年前。 假设我有一个像这样的数据框,第一列“密
如果我有一个位置或行/列同时用于 A 和 B 位置,请检查 B 是否与 A 成对角线? 1 2 3 4 5 6 7 8 9 例如,我如何检查 5 是否与 7 成对角线? 此外,如果我检查 4 是
MongoDB:索引 一、 创建索引 默认情况下,集合中的_id字段就是索引,我们可以通过getIndexes()方法来查看一个集合中的索引 > db.user.getIndexes() [ { "v
一、索引介绍 索引是一种用来快速查询数据的数据结构。 B+Tree就是一种常用的数据库索引数据结构,MongoDB采用B+Tree 做索引,索引创建在colletions上。 MongoDB不使用索引
我无法决定索引。 就像我有下面的查询需要太多时间来执行: select count(rn.NODE_ID) as Count, rnl.[ISO_COUNTRY_CODE] as Cou
我有这些表: CREATE TABLE `cstat` ( `id_cstat` bigint(20) NOT NULL, `lang_code` varchar(3) NOT NULL,
我正在尝试找到一种方法来提高包含 IP 范围的 mysql 表的性能(在高峰时段每秒最多有 500 个 SELECT 查询(!),所以我有点担心)。 我有一个这种结构的表: id smallint(
jquery index() 似乎无法识别元素之一,总是说“无法读取未定义的属性‘长度’”这是我的代码。mnumber 是导致问题的原因。我需要 number 和 mnumber 才能跟踪使用鼠标,并
我们有一个包含近 4000 万条记录的 MongoDB 集合。该集合的当前大小为 5GB。此集合中存储的数据包含以下字段: _id: "MongoDB id" userid: "user id" (i
文档说:如果你有多个字段的复合索引,你可以用它来查询字段的开始子集。所以如果你有一个索引一个,乙,丙你可以用它查询一种一个,乙a,b,c 我的问题是,如果我有一个像这样的复合索引一个,乙,丙我可以查询
我正在使用 $('#list option').each(function(){ //do stuff }); 循环列表中的选项。我想知道如何获取当前循环的索引? 因为我不想让 var i = 0;循
MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度。 打个比方,如果合理的设计且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL
SQLite 索引(Index) 索引(Index)是一种特殊的查找表,数据库搜索引擎用来加快数据检索。简单地说,索引是一个指向表中数据的指针。一个数据库中的索引与一本书后边的索引是非常相似的。
我是 RavenDB 的新手。我正在尝试使用多 map 索引功能,但我不确定这是否是解决我的问题的最佳方法。所以我有三个文件:Unit、Car、People。 汽车文件看起来像这样: { Id: "
我有以下数据,我想根据范围在另一个表中建立索引 我想要实现的是,例如,如果三星的销售额为 2500,则折扣为 2%,低于 3000 且高于 1000 我知道它可以通过索引来完成,与多个数组匹配,然后指
我正在检查并删除 SQL 数据库中的重复和冗余索引。 所以如果我有两个相同的索引,我会删除。 例如,如果我删除了重叠的索引... 索引1:品牌、型号 指标二:品牌、型号、价格 我删除索引 1。 相同顺
我是一名优秀的程序员,十分优秀!