MongoDB-index

索引:特殊的数据结构,存储表的数据的一小部分以实现快速查询

优点:

    1、大大减少了服务器需要扫描的数据量

    2、索引可以帮助服务器避免排序或使用临时表

    3、索引可以将随机io转换为顺序io

索引评估:三星(非常好)

一星:索引如果能将相关的记录放置到一起

二星:索引中数据的存储顺序与查找标准中顺序一致

三星:如果索引中包含查询中所需要的全部数据:(覆盖索引)

DBA书:关系型数据库索引设计与优化

索引类别:

    顺序索引

    散列索引:将索引映射至散列桶上,映射是通过散列函数进行的

评估索引的标准:

    访问类型:做等值比较用散列索引,用范围比较时用顺序索引

    访问时间:

    插入时长:

    删除时长:

    空间开销:

顺序索引:

    聚集索引:如果某记录文件中的记录顺序是按照对应的搜索码指定的顺序排序,聚集索引页成为主索引

    非聚集索引:搜索码中的指定的次序与记录文件中的记录次序不一致

    有聚集索引的数据文件,也叫做索引顺序文件

    根据索引中是否为每个记录相应的创建索引项,可分为稠密索引和稀疏索引

多级索引:(但对频繁修改的数据,性能很差)

    辅助索引必须是稠密索引

B+树索引:顺序索引

    Balance Tree:平衡树索引

顺序索引的特性:

    全值匹配:Name='user12'

    匹配最左前缀:Name LIKE  'User1%',无效:Name LIKE '%User1%'

    匹配列前缀:Name LIKE  'User1%',无效:Name LIKE '%User1%'

    匹配范围值

    精确匹配某一列并范围匹配另外一列:

    只访问索引的查询

散列索引:

    散列函数:

        分布随机

        分布均匀

适用场景:

    精确匹配:=,IN(),<=>

   

Mysql:全文索引,fulltext

    sphinx,lucene

    空间索引:必须使用空间索引函数获取相应的查询结果

    主键、唯一键

Mysql:创建索引

    create index index_name on table (col1,…)

    alter table add index

    alter table drop index

    drop index index_name from table

    show indexes from table

Mongodb创建索引:

    id字段就有主索引

在Name创建索引:

图片.png

 查看所有:

图片.png

默认在id上创建了主索引

唯一索引:

db.collection.ensureIndex({"user_id":1},{unique:true})

sparse index:稀疏索引

db.collection.ensureIndex({"user_id":1},{sparse:true})

Mongodb:

索引可以创建在collection上,也可以创建在子文档中

Mongodb索引类型:

    单键索引

    组合索引

    多键索引:

    空间索引

    文本索引

    hash索引

hash索引:
图片.png

删除索引:

图片.png

或者

图片.png

db.mycoll.dropIndexes():删除mycoll的所有索引

查询过程:explain

图片.png

扫描了100个数据

创建索引后,只扫描一个数据

图片.png

指定索引:

图片.png

创建组合索引:

图片.png

通过组合索引查询:

> db.testcoll.find({Name:'User19'}).hint({Name:1,Age:1}).explain()
{
    "cursor" : "BtreeCursor Name_1_Age_1",
    "isMultiKey" : false,
    "n" : 1,
    "nscannedObjects" : 1,
    "nscanned" : 1,
    "nscannedObjectsAllPlans" : 1,
    "nscannedAllPlans" : 1,
    "scanAndOrder" : false,
    "indexOnly" : false,
    "nYields" : 0,
    "nChunkSkips" : 0,
    "millis" : 0,
    "indexBounds" : {
        "Name" : [
            [
                "User19",
                "User19"
            ]
        ],
        "Age" : [
            [
                {
                    "$minElement" : 1
                },
                {
                    "$maxElement" : 1
                }
            ]
        ]
    },
    "server" : "stu:27017"
}

原创文章,作者:黑白子,如若转载,请注明出处:http://www.178linux.com/61034

(0)
黑白子黑白子
上一篇 2016-11-27 16:25
下一篇 2016-11-27 18:51

相关推荐

  • N25期–第六周作业

    请详细总结vim编辑器的使用并完成以下练习题 1、 复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; %s@^[[:space:]]\{1,\}.*@#&@ 2、 复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf…

    Linux干货 2017-01-17
  • Http虚拟主机的应用

    一、http 1、 基于主机名实现三个虚拟主机 (1)yum安装httpd (2)注释中心主机的网页路径 (3)创建三个虚拟机主机的文件路径 (4)创建三个虚拟机主机的文件网页index.html (5)更改hosts文件进行映射 (6)关闭防火墙和Selinux进行测试(测试步骤是在本机的虚拟机上测试) 2、每虚拟主机使用独立的访问日志和错误日志 (1)给…

    Linux干货 2016-10-08
  • rsync+inotify实现数据实时备份

    rsync+inotify实现数据实时备份 §·rsync简单介绍 1 §·什么是rsync 1 §·rsync的功能特性 1 §·rsync的优点和不足 2 §·初识inotify 2 §·rsync命令工作模式 2 §·rsync常用命令选项 3 §·配置rsync以守护进程的方式运行 3 ※·安装并启动 xinetd 3 ※·为rsync服务器提供配置…

    Linux干货 2016-10-30
  • 大数据计算:如何仅用1.5KB内存为十亿对象计数

    Big Data Counting: How To Count A Billion Distinct Objects Using Only 1.5K This is a guest post by Matt Abrams (@abramsm), from Clearspring, discussing how they are able to accurat…

    Linux干货 2015-04-08
  • 个人思想的转变及对学习的态度

    了解linux已经一年多了,但实际上学习的次数并不多。我是在部队的时候通过网络了解到linux,刚开始接触的是乌班图系统,感觉这个系统美化比较漂亮,就安装在虚拟机里进行各种操作,但是对命令是一窍不通的,都是通过百度粘贴复制各种命令,在复制的是同时我也感觉到头大,这个系统的输入、输出怎么都是字母出现在屏幕上,顿时就感到兴趣失去了一大半,再加上自己英语也不好,就…

    Linux干货 2018-03-26
  • linux入门及基本命令

    Linux的入门及基本命令     一.   磁盘分区 1.       分区类型 主分区:1-4,一个硬盘最多四个,最少可以没有,前提有别的硬盘存在,启动系统或存数据,不要再分小区,只有个活动状态。 2.    &nb…

    Linux干货 2017-07-15