mongodb查询操作

1.查询操作

db.getCollection('example_data_1').find({})  查询所有的信息,相当于mysql中的select * from table_name;

2.查询特定条件的就需要在

db.getCollection('example_data_1').find({})中find({})中大括号中设定条件

   # 查询在集合example_data_1中,年龄在21和25之间的信息。

 db.getCollection('example_data_1').find({'age':{'$lt':25,"$gt":21}})

$lt -->less than --> 小于

$gt-->great than -->大于

$lte -->less than and equal -->小于等于

$gte -->great than and equal -->大于等于

$ne --> not equal -->不等于

记住英文就很好记住这些表达式

db.getCollection('example_data_1').find({‘title’:"第一章"}) ,查询条件是通过字典类型设置条件。查询title等于第一章的所有信息。

3.如过要限定字段,格式为:

 db.getCollection("example_data_1").find(用于过滤记录的字典,用于限定字段的字典),其中用于限定字段的字典的key为各个字段名,值只有两个,0或1.

举例子:

  db.getCollection('example_data_1').find({})

查询数据集example_data_1,但不返回“address”和“age”字段,查询语句如下:

db.getCollection('example_data_1').find({},{‘address’:0,"age":0})

4.查询数据又多少条数据

db.getCollection('example_data_1').find({}).count()   # 得到查询数据有多少条

5.限定返回结果,limit()

db.getCollection('example_data_1').find({}).limit(限制返回的条数)

db.getCollection('example_data_1').find({}).limit(2)

6 对查询的结果进行排序 sort()

 db.getCollection('example_data_1').find({'age':"$gt":21}).sort({"字段名":-1/1}) 其中-1表示倒序,1表示正序。

  

7 修改数据

update操作,对应的MongoDB命令为updateOne()或updateMany()

区别:

updateOne():只更新第一条满足要求的数据。

updateMany():更新所有满足要求的数据。

db.getCollection('example_data_1').updateMany(

 参数1:查询语句的第一字典,

  (‘$set’:{'字段1':“新的数值1”,“字段2”:“新的数值2”})   

)

  updatemany()第一个参数和find()参数一样,是一个字典,用来寻找所有需要被更新的记录。

db.getCollection("example_data_1").updateMany({"name":"张小二"},{"$set":{"work":"工程师"}})

8删除数据

要从example_date_1中删除字段“hello”值为world的这一条记录。

8.1 从集合中删除单条数据

8.2 从集合中删除多条数据。只要会查询数据,就会删除数据,为了误删除数据,一般做法都是先查询要删除的数据,,然后再将查出的数据删除。

db.getCollection('example_data_1').find({"hello":"world"})
先查询出需要删除的数据

再把find修改为deleteOne,只删除第一条满足要求的数据,或者把find修改为deleteMany,如果要删除所有满足要求的数据。

在返回的数据中,”acknowledged“:true 表示删除成功,deletedCount:表示一共删除几条数据。

再次查询

没有数据。

AttentionsPlease

  一般工程会使用”假删除“,为数据增加”deleted“字段,如果为0表示没有删除,值为1为已经删除。

9 去重操作,和mysql使用相同的关键字distinct()

db.getCollection("example_data_1").distinct("age")

对特定条件数据去重

db.getCollection("example_data_1").distinct("age",{‘age’:{"$gte":10}})

左手Mongodb右手Redis 第三章mongdb操作的更多相关文章

  1. 左手Mongodb右手Redis redis操作

    set key value  设置key的值 get key 取得key的值 decr key 值会减一 incr key 值会加一 decrby key value ,会让key的值减少value. ...

  2. 左手Mongodb右手Redis 第一章,进入Mongodb和Redis的世界

    ---恢复内容开始--- 1,为什么要使用非关系型数据库,关系型数据库咋滴,不能用嘛? 存在即合理,非关系型数据库的出现,那说明关系型数据库不适用了. 非关系型数据库(NOSQL)-->Not ...

  3. 左手Mongodb右手Redis

    第二章,了解Mongodb保存数据 Mongodb对于每次插入的数据没有要求,字段可以随便变动,字段类型可以随意变动. Mongodb可以并发插入上万条文档,这是传统关系型数据库不能望其项背的. 1. ...

  4. 左手Mongodb右手Redis 通过python连接mongodb

    首先需要安装第三方包pymongo pip install pymongodb """ 通过python连接mongodb数据库 首先需要初始化数据库连接 "& ...

  5. 第三章 JavaScript操作BOM对象

    第三章   JavaScript操作BOM对象 一.window对象 浏览器对象模型(BOM)是javascript的组成之一,它提供了独立与浏览器窗口进行交换的对象,使用浏览器对象模型可以实现与HT ...

  6. 2 python第三章文件操作

    1.三元运算 三元运算又称三目运算,是对简单的条件语句的简写,如: 简单条件语句: if 条件成立: val = 1 else: val = 2 改成三元运算: val = 1 if 条件成立 els ...

  7. jQuery 实战读书笔记之第三章:操作 jQuery 集合

    创建新 HTML 元素 $('<div>Hello</div>'); /* 创建等价的空 div 元素 */ $('<div>'); $('<div /> ...

  8. JQuery制作网页—— 第三章 JavaScript操作DOM对象

    1. DOM:Document Object Model(文档对象模型):          DOM操作:                   ●DOM是Document Object Model的缩 ...

  9. 第三章 JavaScript操作Dom对象

    常用的方法: 1.访问节点: 通过Document.getElementByXXX()获得一个指定节点-->再通过以下属性节点访问节点:第一部分:节点属性a:parentNode 返回节点的父节 ...

随机推荐

  1. 标准标签库JSTL(JSP Standard Tag Library)

    1, 核心标签(最常用, 最重要的) 表达式控制标签 out 输出常量 value---直接赋值 输出变量 default---默认值 escapeXml---控制转义字符(默认为true, 如果需要 ...

  2. MFC---导出 Excel 方法

    本方法通过Excel驱动写入 请添加头文件 #include"afxdb.h" 第一步创建Excel文件 安装驱动 CString FileName = L"first. ...

  3. seaborn教程4——分类数据可视化

    https://segmentfault.com/a/1190000015310299 Seaborn学习大纲 seaborn的学习内容主要包含以下几个部分: 风格管理 绘图风格设置 颜色风格设置 绘 ...

  4. installing-sql-server-2012-error-prior-visual-studio-2010-instances-requiring 转摘

    there are two way: First : Inside your CD of SQL Server 2012 you can go to this path \redist\VisualS ...

  5. css中一些文本属性的用法

    代码 /* text-transform用法 */ .p1 { /* 默认值 */ text-transform: none; } .p2 { /* 每个单词的首字母大写 */ text-transf ...

  6. vsftpd.service: Main process exited, code=exited, status=2/INVALIDARGUMENT和vsftpd:500 OOPS: vsftpd: refusing to run with writable root inside chroot ()错误的解决方法

    今天在配置VSFTPD过程中遇到两个错误 1是启动失败,通过 SERVICE VSFTPD STATUS 查看到报错 May 02 16:06:58 debian systemd[1]: Starti ...

  7. 【记录】elastiasearch 6.4.3 版本 SearchRequestBuilder字段排序,BoolQueryBuilder

    参考地址: 1:https://www.cnblogs.com/shoutn/p/8027960.html 2:https://www.jianshu.com/p/8402eb930ae7 3:htt ...

  8. Redis这篇就够了

    Redis 简介 Redis 优势 Redis 数据类型 string hash list set Zset 小总结 基本命令 发布订阅 简介 实例 发布订阅常用命令 事务 实例 Redis 事务命令 ...

  9. U盘装CENTOS操作系统

    一.制作U盘系统镜像 1).用UltralISO软件打开下载好的ISO文件镜像,“文件”-“打开”,选中下载好的ISO镜像 2)点击“启动”-“写入硬盘镜像”,选中需要写入的U盘(容量最少为8G),点 ...

  10. Sass Maps的函数-map-remove($map,$key)、keywords($args)

    map-remove($map,$key) map-remove($map,$key) 函数是用来删除当前 $map 中的某一个 $key,从而得到一个新的 map.其返回的值还是一个 map.他并不 ...