左手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之间的信息。

1 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.如过要限定字段,格式为:

1 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()

1 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}})

原文地址:https://www.cnblogs.com/hamish26/p/11356490.html

时间: 2024-10-05 05:05:16

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

第三章 表操作

创建表 CREATE TABLE user( id INT PRIMARY KEY AUTO_INCREMENT, username VARCHAR(20) NOT NULL UNIQUE KEY, userpwd VARCHAR(20) NOT NULL, age TINYINT UNSIGNED DEFAULT 0, sex ENUM('1','2','2') DEFAULT '1', salary FLOAT(8,2) UNSIGNED ); AUTO_INCREMENT必须与PRIMAR

第三章 文件操作

底层文件访问 文件描述符: 0:标准输入 1:标准输出 2:标准错误 write系统调用 把缓冲区buf的前nbytes个字节写入与文件描述符fildes关联的文件中.返回实际写入的字节数.返回0表示未写入,返回-1表示错误. #include <unistd.h> size_t write(int fildes,const void *buf,size_t nbytes) #include<unistd.h> #include<stdlib.h> int main()

MongoDB学习笔记(三)

第三章 索引操作及性能测试 索引在大数据下的重要性就不多说了 下面测试中用到了mongodb的一个客户端工具Robomongo,大家可以在网上选择下载.官网下载地址:http://www.robomongo.org/ 插入 测试数据 首先插入100万条测试数据 for(var i=1;i<1000000;i++){ var person={ Name:"jack"+i, Age:i, Address:["henan","wuhan"], C

linux程序设计——文件操作(第三章)

第三章    文件操作 3.1 linux文件结构 与UNIX一样,linux环境中的文件具有特别重要的意义,因为它们为操作系统服务和设备提供了一个简单而一致的接口.在linux中,一切都是文件. 这意味着,通常程序可以像使用文件那样使用磁盘文件.串行口.打印机等等. 目录也是文件,但它是一种特殊类型的文件.在现代UNIX(包括linux)版本中,即使是超级用户可能也不再被允许直接对目录进行写左操作了.所有用户通常都使用上层的opendir/readdir接口来读取目录,而无需了解特定系统中目录

MySQL、MongoDB、Redis 数据库之间的区别与使用(本章迭代更新)

MySQL.MongoDB.Redis 数据库之间的区别与使用 MySQL.MongoDB.Redis 数据库之间的区别与使用(本章迭代更新) update:2019年2月20日 15:21:19(本章迭代更新) 一.数据库之间的区别 MySQL MySQL概述 关系型数据库.无论数据还是索引都存放在硬盘中.到要使用的时候才交换到内存中.能够处理远超过内存总量的数据. 在不同的引擎上有不同 的存储方式. 查询语句是使用传统的 SQL 语句,拥有较为成熟的体系,成熟度很高. 开源数据库的份额在不断

数据库应用(Mysql、Mongodb、Redis、Memcached、CouchDB、Cassandra)

目前,主流数据库包括关系型(SQL)和非关系型(NoSQL)两种. 关系数据库是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据,支持复杂的事物处理和结构化查询.代表实现有MySQL.Oracle.PostGreSQL.MariaDB.SQLServer等. 非关系数据库是新兴的数据库技术,它放弃了传统关系型数据库的部分强一致性限制,带来性能上的提升,使其更适用于需要大规模并行处理的场景.非关系型数据库是关系型数据库的良好补充,代表产品有MongoDB.Memca

左手握右手

报载,有一中年男子酒宴间“朗诵”了一首据说是眼下颇为流行的顺口溜:“握着小姐的手,好像回到十八九,握着情人的手,一股暖流涌心头,握着小姨子的手,后悔当年握错了手,握着老婆的手,好像左手握右手.”于是,男人们爆发出一阵会意放浪的笑声.然而,有位女士没笑,一番口吐珠玑,实在令人刮目相看,故择其精要草录于此:“妙哉,妙哉!这‘左手握右手’实乃旷世一绝.第一,左手可以被右手信赖:第二,左手和右手一样,都是自己的:第三,别的手任怎样令你愉悦.兴奋.魂飞魄散,过后都是可以甩手的.只有左手和右手,甩了一只就残

Docker运行MongoDB及Redis及ssh端口映射远程连接

Docker运行MongoDB及Redis及ssh端口映射远程连接 本节内容简介 在本实验里我们将通过完成 MongoDB 和 Redis 两个容器来学习Dockerfile及Docker的运行机制. 本节中,我们需要依次完成下面几项任务: MongoDB 的安装及配置 Redis 的安装及配置 Dockerfile 的编写 从 Dockerfile 构建镜像 本次实验的需求是完成 Dockerfile,通过 Dockerfile 创建 MongoDB 或 Redis 应用.Dockerhub上

搭建高可用mongodb集群(三)—— 深入副本集内部机制

http://www.lanceyan.com/tech/mongodb_repset2.html 在上一篇文章<搭建高可用mongodb集群(二)—— 副本集> 介绍了副本集的配置,这篇文章深入研究一下副本集的内部机制.还是带着副本集的问题来看吧! 副本集故障转移,主节点是如何选举的?能否手动干涉下架某一台主节点. 官方说副本集数量最好是奇数,为什么? mongodb副本集是如何同步的?如果同步不及时会出现什么情况?会不会出现不一致性? mongodb的故障转移会不会无故自动发生?什么条件会