Nosql中MongoDB简单的查询练习

查询练习一部分:

//1.进入my_test数据库use my_test

//2.向数据库的user集合中插入一个文档 db.users.insert({username:"孙悟空"});

//3.查询user集合中的文档db.users.find();

//4.向数据库的user集合中插入一个文档db.users.insert({username:"孙娇娇"}); 

//5.查询数据库user集合中的文档 db.users.find();

//6.统计数据库user集合中的文档数量db.users.find().count();

//7.查询数据库user集合中username为孙悟空的文档db.users.find({username:"孙悟空"});

//8.向数据库user集合中的username为孙悟空的文档,添加一个address属性,属性值为花果山db.users.update({username:"孙悟空"},{$set:{address:"花果山"}});

//9.使用{username:"唐僧"} 替换 username 为 孙娇娇的文档db.users.replaceOne({username:"孙娇娇"},{username:"唐僧"});

//10.删除username为孙悟空的文档的address属性db.users.update({username:"孙悟空"},{$unset:{address:1}});

//11.向username为孙悟空的文档中,添加一个hobby:{cities:["beijing","shanghai","shenzhen"] , movies:["sanguo","hero"]}//MongoDB的文档的属性值也可以是一个文档,当一个文档的属性值是一个文档时,我们称这个文档叫做 内嵌文档db.users.update({username:"孙悟空"},{$set:{hobby:{cities:["beijing","shanghai","shenzhen"] , movies:["sanguo","hero"]}}});db.users.find();

//12.向username为唐僧的文档中,添加一个hobby:{movies:["A Chinese Odyssey","King of comedy"]}db.users.update({username:"唐僧"},{$set:{hobby:{movies:["A Chinese Odyssey","King of comedy"]}}});db.users.find();

//13.查询喜欢电影hero的文档//MongoDB支持直接通过内嵌文档的属性进行查询,如果要查询内嵌文档则可以通过.的形式来匹配//如果要通过内嵌文档来对文档进行查询,此时属性名必须使用引号 db.users.find({‘hobby.movies‘:"hero"});

//14.向唐僧中添加一个新的电影Interstellar//$push 用于向数组中添加一个新的元素//$addToSet 用于向数组中添加一个新的元素db.users.update({username:"唐僧"},{$push:{"hobby.movies":"Insterstellar"}});db.users.find();

//15.删除喜欢beijing的用户db.users.remove({"hobby.cities":"beijing"});db.users.find();

//16.删除user集合db.users.remove({});db.users.drop();show dbs;

//17.向numbers中插入20000条数据 //31.5sfor(var i=1 ; i<= 20000; i++){ db.numbers.insert({num:i});}db.numbers.find();

db.numbers.remove();

//1.7svar arr = [];for(var i =1;i<=20000; i++){arr.push({num:i});}db.numbers.insert(arr);

db.numbers.remove();

查询练习二部分:
//18.查询numbers中num为500的文档db.numbers.find({num:500});

//19.查询numbers中num大于5000的文档//$qt:大于//$eq:等于//$lt:小于db.numbers.find({num:{$gt:5000}});

//20.查询numbers中num小于30的文档db.numbers.find({num:{$lt:30}});

//21.查询numbers中num大于40小于50的文档db.numbers.find({num:{$gt:40,$lt:50}});

//22.查询numbers中num大于19996的文档db.numbers.find({num:{$gt:19996}});

//23.查看numbers集合中的前10条数据db.numbers.find({num:{$lte:10}});

//limit()设置显示数据的上限db.numbers.find().limit(10);

//在开发时,我们绝对不会执行不带条件的查询db.numbers.find(); 

//24.查看numbers集合中的第11条到20条数据/* 分页 每页显示10条 1-10011-201021-3020 。。。 skip((页码-1) * 每页显示的条数).limit(每页显示的条数); skip()用于跳过指定数量的数据 MongoDB会自动调整skip和limit的位置*/db.numbers.find().skip(10).limit(10);

//25.查看numbers集合中的第21条到30条数据db.numbers.find().skip(20).limit(10);
查询练习第三部分:
//26.将dept和emp集合导入到数据库中db.dept.find();db.emp.find();

//27.查询工资小于2000的员工db.emp.find(sal:{$lt:2000});

//28.查询工资在1000-2000之间的员工db.emp.find(sal:{$lt:2000,$gt:1000});

//29.查询工资小于1000或大于2500的员工//$or:[]db.emp.find({$or:[{sal:{$lt:1000}},{sal:{$gt:2500}}]});

//30.查询财务部的所有员工//(depno)db.dept.find({});var depno = db.dept.findOne({dname:"财务部"}).deptno;db.emp.find({depno:depno});

//31.查询销售部的所有员工var depno = db.dept.findOne({dname:"销售部"}).deptno;db.emp.find({depno:depno});

//32.查询所有mgr为7698的所有员工db.emp.find({mgr:7698});

//33.为所有薪资低于1000的员工增加工资400元db.emp.updateMany({sal:{$lte:1000}},{$inc:{sal:400}});db.emp.find();


原文地址:https://www.cnblogs.com/sunjiaojiao/p/11184888.html

时间: 2024-10-03 16:23:26

Nosql中MongoDB简单的查询练习的相关文章

nosql之mongodb简单安装与命令使用

nosql:非关系型,分布式,不提供ACID 简单数据模型 元数据和应用数据分离 弱一致性 优势: 避免不必要的复杂性 高吞吐量 高水平扩展能力和低端硬件集群 不使用对象-关系映射 劣势: 不支持ACID特性 功能简单 没有统一的数据查询模型 ACID:atomicity原子性.consistency一致性.isolation隔离.durability持久性 nosql分类: 列式数据库(按列管理) 键值存储 文档数据库(每一行当做一个实体,独立的文件) 图存数据库(有复杂关系的图存对象),在社

Nosql中MongoDB的介绍

一.MongoDB的认识 基本简介 mongodb是一种介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的,语法有点类似javascript面向对象的查询语言,它是一个面向集合的,模式自由的文档型数据库,MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成.MongoDB 文档类似于 JSON 对象.字段值可以包含其他文档,数组及文档数组 mongodb概念解析 文档 文档是mongodb中数据的基本单元,类似关系数据库的行,多个

MongoDB简单使用-查询操作3

首先添加几个文档: dvd = ({"Type":"DVD","Title":"Matrix,The","Released":1994,"Cast":["Keanu Reeves","Carrie-Anne Moss","Laurence Fishburne","Hugo Weaving","Glo

【一步步学习MongoDB】——MongoDB简单介绍(一)

上篇博文我们大话了一下,什么是NoSQL.我们对NoSQL有了一个全面的认识,从这篇博文开始,将带领大家走入MongoDB的世界,下面我们开始介绍MongoDB. 什么是MongoDB? 我们直接看MongoDB官网的最权威解释:MongoDB (from "humongous") is an open-source document database, and the leading NoSQL database. Written in C++. 翻译:MongoDB的名字来自于&q

MongoDB的使用学习之(七)MongoDB的聚合查询(两种方式)附项目源码

先来张在路上-- 此项目是用Maven创建的,没有使用Maven的,自己百度.谷歌去:直接用Junit测试就行,先执行里面的save方法,添加10000条测试数据提供各种聚合查询等. 废话不多说,上干货-- 一.MongoDB数据库的配置(mongodb.xml) 以下是我自己的配置,红色字体请改为自己本机的东东,你说不懂设置端口,不会创建数据库名称,不会配置用户名密码,那有请查阅本系列的第4节(MongoDB的使用学习之(四)权限设置--用户名.密码.端口==),你说懒得设置,那就@#¥%--

nosql数据库MongoDB的用法

MongoDB常用命令 1.启动命令 mongod 启动数据库进程 --dbpath 制定数据库的目录 --port 制定数据库的端口,默认是27017 --bind_ip 绑定IP --directoryperdb 为每个db创建一个独立子目录 --logpath 制定日志存放目录 --logappend 指定日志生成方式(追加/覆盖) 例如:mongod --dbpath db --port 27098 --directoryperdb --logpath db\logs\mongodb.l

MongoDB 进阶-关联查询

[苏州需要工作的加我QQ,内推介绍费平分] MongoDB 进阶 1.数据库命令 a.命令的工作原理 drop命令,在shell中删除一个集合,执行db.refactor.drop().其实这个函数实际运行的是drop命令, 可以用runCommand来达到一样的效果: db.runCommand({"drop":"refactor"}) {         "nIndexesWas" : 1,         "msg" :

Asp.Net Mvc+MongoDB简单增删查改

                                   Asp.Net Mvc+MongoDB简单增删查改 概要:现在很多企业都在使用非关系型的NoSql数据库,其中MongoDB是相当热门的,最近有空就研究了一下,本文写了一套基于Asp.Net Mvc和MongoDB的简单增删查改,本文部分内容是借用其他博文,最后我会贴出出处. 正文: 在控制器的Models中新建一个UserModel模型(其中相当于另开一个类库,类似Dal层) using System; using Syst

NoSql之Mongodb日常操作命令整理

1.db.serverStatus()  看看分片性能信息 db.serverStatus().connections;分片查看客户端连接数,mongod和mongos的连接属于长连接 "connections" : {                "current" : 737, --当前活动连接量.连接到server的当前活跃连接数目                "available" : 82 --剩余空闲连接量.剩余的可用连接数目