mongo(三)基本操作

mongo(三)基本操作

mongo(三)基本操作

本文来自mongodb官方文档的部分翻译以及自己的理解。
 
CRUD:增加(Create)、读取(Retrieve)(重新得到数据)、更新(Update)和删除(Delete)几个单词的首字母简写。
mongodb是以文件形式存储数据的,像json一样的field-value。
 
mongo(三)基本操作
 
 
mongodb读操作
 
一般来说,一张图能说明很多问题
mongo(三)基本操作
 
mongodb把所有的文件存储在collections中,一个collections是由一些相关的文件组成的,类似与关系数据库中的表。
 
mongo(三)基本操作
在mongodb中,query是针对collections的(可以理解为针对表table);
query请求中包括请求条件,从而可以在collections中挑选目标信息返回;
modifier一般会包含limits,skips和sort orders等操作,对数据进行进一步的处理。
mongo(三)基本操作
 
db.records.find( { "user_id": { $lt: 42 } }, { "history": 0 } )
可以通过设置第二个{}字典来设置显示的字段(fields)信息,在这里history设置为0,表示history字段不需要显示,反之,设置为1的话只显示history字段
db.records.find( { "user_id": { $lt: 42 } }, { "name": 1, "email": 1 } )
如上,这里就是只显示两个字段信息,name和email

cursor
cursor在mongodb中仍然存在,默认情况下cursor关闭的时间为10分钟无操作之后。可以通过:cursor.addOption()来设置cursor的属性:

mongo(三)基本操作
mongodb返回的数据是分批返回的,默认情况下第一次返回101 documents(最多不超过1 megabyte,后续批量大小是4 mb),可通过
batchSize() and 
limit()来改变返回数据的数量。
 
添加索引
在mongodb的shell下,通过
db.collection.ensureIndex() 命令来添加索引字段信息,可以使用
explain() 来查询一次查询相关的统计信息。
db.inventory.ensureIndex( { type: 1 } )
db.inventory.ensureIndex( { type: 1, item: 1 } )

分片集群读取操作

mongo(三)基本操作

mongos,数据库集群请求的入口,所有的请求都通过mongos进行协调,不需要在应用程序添加一个路由选择器,mongos自己就是一个请求分发中心,它负责把对应的数据请求请求转发到对应的shard服务器上。在生产环境通常有多mongos作为请求的入口,防止其中一个挂掉所有的mongodb请求都没有办法操作。

config server,顾名思义为配置服务器,存储所有数据库元信息(路由、分片)的配置。mongos本身没有物理存储分片服务器和数据路由信息,只是缓存在内存里,配置服务器则实际存储这些数据。mongos第一次启动或者关掉重启就会从 config server 加载配置信息,以后如果配置服务器信息变化会通知到所有的 mongos 更新自己的状态,这样 mongos 就能继续准确路由。在生产环境通常有多个 config server 配置服务器,因为它存储了分片路由的元数据,这个可不能丢失!就算挂掉其中一台,只要还有存货, mongodb集群就不会挂掉。

mongodb支持javascript的基本语法

定义变量

var xxx = {“xx”,”xx”}
插入数据库 
db.xxx.insert(xxx)

查找条件

①: >, >=, <, <=, !=, =
在mongodb中对应于”$gt”, “$gte”, “$lt”, “$lte”, “$ne”,和shell比较大小的相同
mongo(三)基本操作
②:and,ro,in,nin
and其实就是默认的搜索条件,不需要添加and
mongo(三)基本操作
 
②:正则表达式
mongo(三)基本操作
$where语句
 
update更新 inc累加 set设置
mongo(三)基本操作
 
mongo(三)基本操作
upsert语句,如果没有就要插入
具体格式为db.database.update({“xx”:”xx”}, {$inc:{“xx”:”xx”}}, true)
mongo(三)基本操作

limit和skip
mongo(三)基本操作

转载于:https://www.cnblogs.com/coder2012/p/4130681.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109641.html原文链接:https://javaforall.net

(0)
上一篇 2021年9月2日 下午1:00
下一篇 2021年9月2日 下午1:00


相关推荐

  • shor算法

    shor算法1 RSA 算法 RSA 作为公钥加密 它的安全性主要依赖于大数分解的难度 根据整数唯一分解定理我们可以知道 p 和 q 就是 n 的唯一的素因子分解形式 其中 n 是正奇合数 p q 均为素数 利用经典方式将 n 分解成两个素数的乘积形式对于大数而言是很困难的 但是根据 shor 算法我们可以解决这个难题 2 shor 算法流程在介绍 shor 算法之前 我们需要知晓 order finding 算法是什么 其实就是求阶 r 的一个过程 过程如下 后期填坑 我们可以将 n 的因式分解问题归纳到求阶问题 我们先来介绍两个重

    2026年3月19日
    2
  • java二维数组初始化(动态,静态)

    java二维数组初始化(动态,静态)int[][] a=new  int[][]{{1,2},{3,4},{5,6,7,8,9},{}};      System.out.println(a.length);//4,表示数组的行数      System.out.println(a[0].length);//2,表示对应行的长度      System.out.println(a[1].length);//2      System…

    2022年5月26日
    36
  • iOS-class方法和objc_getClass方法

    iOS-class方法和objc_getClass方法根据上一篇博客iOS-class、object_getClass、objc_getClass、objc_getMetaClass区别的研究发现,qi’s

    2022年6月29日
    24
  • 天翼云推出智能工作流助手 OpenClaw 提供多种云端部署方案

    天翼云推出智能工作流助手 OpenClaw 提供多种云端部署方案

    2026年3月13日
    2
  • Android 通信Ril

    Android 通信Ril1 总体框架 Rild 是 Init 进程启动的一个本地服务 这个本地服务并没有使用 Binder 之类的通讯手段 而是采用了 socket 通讯这种方式 Andoid 将 RIL 层分为两个代码空间 RILD 管理框架 rild libril so AT 相关的 xxxril so 动态链接库 libreference ril so rild 把 libril so 和 libreference ril so 联系起来

    2026年3月19日
    2
  • 不是单组分组函数「建议收藏」

    不是单组分组函数「建议收藏」问题:一:SELECT tablespace_name, SUM(bytes) freeFROM dba_free_space不是单组分组函数原因: 1、如果程序中使用了分组函数,则有两种情况可以使用:程序中存在group by,并指定了分组条件,这样可以将分组条件一起查询出来改为:  SELECT tablespace_name, SUM(bytes) freeFROM dba_free_spa…

    2022年6月30日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号