左手Mongodb右手Redis 第三章mongdb操作
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操作的更多相关文章
- 左手Mongodb右手Redis redis操作
set key value 设置key的值 get key 取得key的值 decr key 值会减一 incr key 值会加一 decrby key value ,会让key的值减少value. ...
- 左手Mongodb右手Redis 第一章,进入Mongodb和Redis的世界
---恢复内容开始--- 1,为什么要使用非关系型数据库,关系型数据库咋滴,不能用嘛? 存在即合理,非关系型数据库的出现,那说明关系型数据库不适用了. 非关系型数据库(NOSQL)-->Not ...
- 左手Mongodb右手Redis
第二章,了解Mongodb保存数据 Mongodb对于每次插入的数据没有要求,字段可以随便变动,字段类型可以随意变动. Mongodb可以并发插入上万条文档,这是传统关系型数据库不能望其项背的. 1. ...
- 左手Mongodb右手Redis 通过python连接mongodb
首先需要安装第三方包pymongo pip install pymongodb """ 通过python连接mongodb数据库 首先需要初始化数据库连接 "& ...
- 第三章 JavaScript操作BOM对象
第三章 JavaScript操作BOM对象 一.window对象 浏览器对象模型(BOM)是javascript的组成之一,它提供了独立与浏览器窗口进行交换的对象,使用浏览器对象模型可以实现与HT ...
- 2 python第三章文件操作
1.三元运算 三元运算又称三目运算,是对简单的条件语句的简写,如: 简单条件语句: if 条件成立: val = 1 else: val = 2 改成三元运算: val = 1 if 条件成立 els ...
- jQuery 实战读书笔记之第三章:操作 jQuery 集合
创建新 HTML 元素 $('<div>Hello</div>'); /* 创建等价的空 div 元素 */ $('<div>'); $('<div /> ...
- JQuery制作网页—— 第三章 JavaScript操作DOM对象
1. DOM:Document Object Model(文档对象模型): DOM操作: ●DOM是Document Object Model的缩 ...
- 第三章 JavaScript操作Dom对象
常用的方法: 1.访问节点: 通过Document.getElementByXXX()获得一个指定节点-->再通过以下属性节点访问节点:第一部分:节点属性a:parentNode 返回节点的父节 ...
随机推荐
- MySQL- 查询总结
查询总结 语法: select 查询字段 from 表 别名 连接类型inner|left|right join on 连接条件 where 筛选 group by 分组列表 having 筛选(二次 ...
- 《JAVA设计模式》之观察者模式(Observer)
在阎宏博士的<JAVA与模式>一书中开头是这样描述观察者(Observer)模式的: 观察者模式是对象的行为模式,又叫发布-订阅(Publish/Subscribe)模式.模型-视图(Mo ...
- 洛谷 P3368 【模板】树状数组 2(区间加,单点查询)
题目链接 https://www.luogu.org/problemnew/show/P3368 树状数组 最基础的用法:https://www.cnblogs.com/yinyuqin/p/1096 ...
- 对于nginx配置文件中的fastcgi_param相关参数的理解
今天在ubuntu中搭建LNMP的时候,遇到了一个问题 在浏览器中访问.php文件的时候,nginx不能正常解析,页面只是空白,后来百度了一下,发现了问题 在nginx的配置文件nginx.conf中 ...
- L The Digits String(没有写完,有空补)
链接:https://ac.nowcoder.com/acm/contest/338/L来源:牛客网 Consider digits strings with length n, how many d ...
- shell 脚本规范
shell 脚本规范 一.背景 1.使用哪一种shell? 必须使用bash shell 2.什么时候使用shell? 数量相对较少的操作 脚本文件少于100行 3.脚本文件扩展名是什么? shell ...
- resolver - 解析器(resolver) 配置文件
总览 (SYNOPSIS) /etc/resolv.conf 描述 (DESCRIPTION) 解析器(resolver) 是 C 函数库 中 的 一组 例程, 用于 访问 Internet 域名系统 ...
- 生成树计数 Matrix-Tree 定理 学习笔记
一直都知道要用Matrix-Tree定理来解决生成树计数问题,但是拖到今天才来学.博主数学不好也只能跟着各位大佬博客学一下它的应用以及会做题,证明实在是不会. 推荐博客: https://www.cn ...
- 前端学习(三十七)angular(笔记)
MVC 后台 M Module 数据层 V View 视图层 C Contro ...
- java 静态内存图、静态代码块
package java08; /* 静态代码块格式: public class 类名称{ static{ //静态代码块 } } 特点:当第一次执行本类时,静态代码块执行唯一的一次 * */ pub ...