位置: 编程技术 - 正文

MongoDB教程之索引介绍(mongodb subtract)

编辑:rootadmin

推荐整理分享MongoDB教程之索引介绍(mongodb subtract),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mongodb $sum,mongodb索引数据结构,mongodb索引,mongodb索引命中规则,mongodb索引命中规则,mongodb索引数据结构,mongodb索引的实现原理,mongodb索引的实现原理,内容如对您有帮助,希望把文章链接给更多的朋友!

一、索引基础:

MongoDB教程之索引介绍(mongodb subtract)

MongoDB的索引几乎与传统的关系型数据库一模一样,这其中也包括一些基本的优化技巧。下面是创建索引的命令: 可以通过下面的名称查看索引是否已经成功建立: 删除索引的命令是: 在MongoDB中,我们同样可以创建复合索引,如: 该索引被创建后,基于username和age的查询将会用到该索引,或者是基于username的查询也会用到该索引,但是只是基于age的查询将不会用到该复合索引。因此可以说,如果想用到复合索引,必须在查询条件中包含复合索引中的前N个索引列。然而如果查询条件中的键值顺序和复合索引中的创建顺序不一致的话,MongoDB可以智能的帮助我们调整该顺序,以便使复合索引可以为查询所用。如: 对于上面示例中的查询条件,MongoDB在检索之前将会动态的调整查询条件文档的顺序,以使该查询可以用到刚刚创建的复合索引。 我们可以为内嵌文档创建索引,其规则和普通文档没有任何差别,如: 对于上面创建的索引,MongoDB都会根据索引的keyname和索引方向为新创建的索引自动分配一个索引名,下面的命令可以在创建索引时为其指定索引名,如: 随着集合的增长,需要针对查询中大量的排序做索引。如果没有对索引的键调用sort,MongoDB需要将所有数据提取到内存并排序。因此在做无索引排序时,如果数据量过大以致无法在内存中进行排序,此时MongoDB将会报错。 二、唯一索引: 在缺省情况下创建的索引均不是唯一索引。下面的示例将创建唯一索引,如: 如果再次插入userid重复的文档时,MongoDB将报错,以提示插入重复键,如: 如果插入的文档中不包含userid键,那么该文档中该键的值为null,如果多次插入类似的文档,MongoDB将会报出同样的错误,如: 如果在创建唯一索引时已经存在了重复项,我们可以通过下面的命令帮助我们在创建唯一索引时消除重复文档,仅保留发现的第一个文档,如: --先删除刚刚创建的唯一索引。 我们同样可以创建复合唯一索引,即保证复合键值唯一即可。如:

三、使用explain: explain是非常有用的工具,会帮助你获得查询方面诸多有用的信息。只要对游标调用该方法,就可以得到查询细节。explain会返回一个文档,而不是游标本身。如: explain会返回查询使用的索引情况,耗时和扫描文档数的统计信息。 "cursor":"BasicCursor"表示没有使用索引。 "nscanned":1 表示查询了多少个文档。 "n":1 表示返回的文档数量。 "millis":0 表示整个查询的耗时。 四、索引管理:

system.indexes集合中包含了每个索引的详细信息,因此可以通过下面的命令查询已经存在的索引,如: 如果在为已有数据的文档创建索引时,可以执行下面的命令,以使MongoDB在后台创建索引,这样的创建时就不会阻塞其他操作。但是相比而言,以阻塞方式创建索引,会使整个创建过程效率更高,但是在创建时MongoDB将无法接收其他的操作。

MongoDB教程之聚合(count、distinct和group) 1.count:--在空集合中,count返回的数量为0。db.test.count()0--测试插入一个文档后count的返回值。db.test.insert({"test":1})db.test.count()1db.test.insert({"test":2})db.test.co

MongoDB教程之基本管理命令 1.启动和停止MongoDB:执行mongod命令启动MongoDB服务器。mongod有很多可配置的选项,我们通过mongod--help可以查看所有选项,这里仅介绍一些主要选项:--dbpat

MongoDB教程之入门基础知识 一、文档的注意事项:1.键值对是有序的,如:{"name":"stephen","genda":"male"}不等于{"genda":"male","name":"stephen"}2.文档信息是大小写敏感的,如:{"name":"stephen"}

标签: mongodb subtract

本文链接地址:https://www.jiuchutong.com/biancheng/312715.html 转载请保留说明!

上一篇:浅谈mongodb中query查询(mongodb reference)

下一篇:MongoDB教程之聚合(count、distinct和group)(mongodb聚合统计数量)

  • 收到退回的以前年度租金怎么处理
  • 经营所得和企业所得
  • 关税完税价格是到岸价吗
  • 什么原始凭证可以填写
  • 增值税专用发票可以开电子发票吗
  • 注册公司工贸和商贸区别
  • 专票没有税点
  • 劳务派遣人员工资可以由用工单位发放么
  • 建筑工程劳保费返还给项目部吗
  • 企业发生事故后的处理流程
  • 农产品增值税进项税额核定扣除试点实施办法
  • 股权转让如何避免土地增值税
  • 简易计税收入会计分录
  • 包装设置图片
  • 工作过失扣工资合法吗
  • 开票交税当月不确认收入如何做账?
  • 部分退货退款剩下的钱什么时候给卖家
  • 采购单录入、接收分配会计分录怎么写?
  • 委托收款有什么用
  • 财产租赁所得个人所得税计算方法2020
  • 进项发票和销项发票金额相同还需要交税金吗
  • 增值税发票查验平台官网网络异常
  • 购进的货物用于赠送
  • 社保企业报盘是什么
  • 合伙人退伙资产清算需要交税吗
  • 特种设备年检费怎么开具发票
  • 商品损耗怎么做会计分录
  • 厂家质量问题商家有责任吗
  • txt文档乱码怎么办
  • 车辆的代驾费应该怎么收
  • php生成唯一标识
  • 企业工会经费计提比例
  • 新版win10任务栏
  • PHP:Memcached::getResultCode()的用法_Memcached类
  • php数组函数,选班长
  • 应交税金的会计科目
  • 短期资金都是债务类资金
  • JavaScript | 1000个判断条件难道要写了1000个 if ? 一文教你如何实现分支优化
  • 设备租赁费属于设备费吗
  • js中的定时器
  • h5项目怎么打包成app
  • typescript中文文档
  • vue中的组件
  • 技术服务型企业企业所得税率
  • 无发生额有没有对账单
  • centos7自带yum吗
  • 水运企业会计核算办法
  • 航空公司开具的代订机票费可以抵扣吗
  • 车辆车船税收费标准
  • 使用mysql命令
  • 失业稳岗补贴怎么领
  • 普通发票和增值税发票报销有什么区别?
  • 工程在建期间的招待费计入什么科目
  • 营业税金及附加和税金及附加有什么区别
  • 固定资产清理后折旧怎么处理
  • 对方开票少开几角会计分录
  • 应收账款冲销是什么意思
  • 新成立的教育机构值得去吗
  • 成本不够如何计算出来
  • 进项税额已抵扣又红字冲红税务系统自动冲回吗
  • 税金及附加没有设置二级科目,有啥影响吗
  • 营业收入和主营业务收入分别在哪看
  • 电脑怎么安装安全控件
  • win10正式版激活码
  • xp怎么删除多余的操作系统
  • Windows Server 2008:手足之争下的赢家
  • mac系统怎么样
  • windows7怎么添加设备
  • win10自带绘画
  • win7系统每次关机都安装更新
  • opengl编译
  • shell bash sh
  • js模拟实现new
  • js处理时间格式
  • javascript给表单赋值
  • jQuery实现HTML表格单元格的合并功能
  • 除了增值税还要什么税种
  • 应交增值税减免税款借贷方向
  • 推进社会治理的路径
  • 四川省地方税务局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设