1、mongoDB简介:mongoDB 为非关系数据库,集合(collection)关系数据库中的表,中存储的为json结构的文档,集合中的每一条记录都可以结构不同,

但必须都有_id字段(mongoDB默认的Object类型的标识)。

2、mongoDB安装:教程链接:Windows下:http://jingyan.baidu.com/article/d5c4b52bef7268da560dc5f8.html

Linux下:http://jingyan.baidu.com/article/fd8044faf4f3a95030137a79.html

3、mongoDB初级查询语句:

mongoDB语句 对应的SQL语句
新建数据库:use mydb;//新建一个数据库mydb create database mydb
查看数据库列表:show dbs //mongoDB自带测试数据库  

新建集合:db.student.insert({'name':'lily',age:NumberInt('18','sex':'女')})

插入新的数据,mongoDB自动创建集合,无数据的集合不会显示在列表中

create table student(
            id varchar(30),
            name varchar(30),
            age int,
            sex varchar(10),
            primary key (id)
        )
查询全部:db.collection.find(); select * from collection;

条件查询:db.collection.find({age:18})

db.collection.find({'sex':'男'})

db.collection.find({age:{$gt:18}})

db.collection.find({age:{$gte:18}})

db.collection.find({age:{$lt:18}})

db.collection.find({age:{$lte:18}})

select * from collection where age=18;

select * from collection where sex='男';

select * from collection where age>18;

select * from collection where age>=18;

select * from collection where age<18;

select * from collection where age<=18;

 查询数量:db.collection.find({age:18}).count();  select count(*) from collection where age=18;
 分页查询:db.collection.find({age:18}).limit(10).skip(5);  select * from collection where age=18 limit 5,10;
 查询指定字段:db.collection.find({age:18},{name:1})  select name from collection where age=18;
插入数据:db.collection.insert({'name':'lucy',age:28})  insert into collection(name,age) values('lucy',28)
删除数据:db.collection.drop({'name':'lucy'}) delete from collection where name='lucy'
更新数据:db.collection.update({'name':'lily'},{$set:{age:19}}) update  collection set age=19 where name='lily';
模糊条件查询:db.collection.find({'name':/li/}) select * from collection where name like %li%;
删除集合:db.collection.drop();  drop table collection;

删除数据库 ues mydb

db.dropDatebase();

 

4、mongoDB 高级查询:

A、聚合:mongoDB 中的aggregate()方法,相当于mysql中的group by。基本语法是:db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION);

eg:db.collection.aggregete([{$match:{age:18}},{$group:{_id:'sex',num:{$sum:1}}}])

对应SQL:select sex count(*) from collection where age=18 group by sex;

B、排序:mongoDB 中的sort()方法,相当于mysql中的order by 。

eg:db.collection.find({'sex':'男'}).sort({age:1});

对应SQL:select * from collection where sex='男' reder by age ASC

db.collection.find({'sex':'男'}).sort({age:-1});

对应SQL:select * from collection where sex='男' reder by age DESC

C.去重:mongoDB中的distinct()方法去重。

eg:db.collection.distinct("name")

对应SQL:select distinct(name) from collection;

D、执行分析:mongoDB中用explain()分析执行过程。

eg:db.collection.find({age:18}).explain();

对应的SQL:explain select * from collection where age=18;

附:explain参数详解:https://my.oschina.net/foreverhui/blog/639240?p={{totalPage}}

5、mongoDB 特有查询:

a、$all匹配所有值

这个操作和SQL的in类似,但是in只需要满足其中的一个值即可,而$all则需要满足所有值。

eg:db.collection.find({age:{$all:[20,21]}})

可以查询出age[20,21,22]但查不出age[20,22,23]即必须同时有20和21。

b、$in查询包含的值

这个操作相当于SQL中的in。

eg:db.collection.find({age:{$in:[20,21]}})

c、$exists判断字段是否存在

eg:查询存在age字段的记录

db.collection.find({age:{$exists:true}})

查询不存在age字段的记录

db.collection.find({age:{$exists:false}})

d、null值的处理

mongoDB 中的null值处理不仅会返回某一字段为null的记录,还会返回不存在该字段的记录

eg:db.collection.find({age:null})

查询结果既有age字段为null的记录还会有不存在age字段的记录。如果需要只查出age字段为null的记录,需要配合$exists

eg:db.collection.find({age:{'$in':[null],'$exists':true}})

查询结果为存在age字段且该字段的值为null

e、$mod取模运算

eg:db.collection.find({age:{$mod:[5,3]}})

查询age取模5为3的记录。

f、$ne不等于操作

eg:db.collection.find({age:{$ne:18}})

g、$nin不包含操作

eg:db.collection.find({age:{$nin:[18,19,20]}})

查询age不等于 18、19、20的记录。

h、JavaScript查询和$where查询

eg:查询年龄大于18的记录有以下四种方式

条件操作符:db.collection.find({age:{$gt:18}})

$where 方式:db.collection.find({$where:'this.age>18'})

内部对象查询:db.collection.find("this.age>18")

JavaScript查询:func = function(){return this.age>18}

db.collection.find(func)

j、存储过程

创建存储过程:db.system.js.save({_id:'addNum',value:function(x,y){return x+y}})

查看所有存储过程:db.system.js.find()

调用存储过程:db.eval("addNum(2,3)")

同时可以直接用db.eval()创建并调用存储过程

db.eval(function (){return 2+3;})

存储过程可以处理数据库内部的操作

db.system.js.save({_id:"getCount",value:function(){return db.collection.find({age:{$gt:18}}).count()}})

将collection中age大于18的记录的数量保存在getCount这个存储过程中,调用时db.eval("getCount()")就可以直接得到那个数量

mongoDB数据库的更多相关文章

  1. Mongodb数据库学习系列————(一)Mongodb数据库主从复制的搭建

    Mongodb数据库主从复制的搭建 Writeby:lipeng                                    date:2014-10-22 最近项目上用到了位置查询,在网上 ...

  2. 基于C#的MongoDB数据库开发应用(4)--Redis的安装及使用

    在前面介绍了三篇关于MongoDB数据库的开发使用文章,严格来讲这个不能归类于MongoDB数据库开发,不过Redis又有着和MongoDB数据库非常密切的关系,它们两者很接近,Redis主要是内存中 ...

  3. FineReport如何连接和使用MongoDB数据库

    随着NoSQL数据库越来越流行,MongoDB数据库作为NoSQL数据库中的领头羊,使用也越来越广泛.为此,FineReport V8.0版本提供了数据连接和数据集接口,可以通过开发一款可以连接和使用 ...

  4. python操作mongodb数据库

    一.MongoDB 数据库操作 连接数据库 import pymongo conn = pymongo.Connection() # 连接本机数据库 conn = pymongo.Connection ...

  5. NoSql 中Mongodb数据库的使用

    1.NoSql数据库简介 2.MongoDB数据库的简介 3.MongoDB下Windows下的安装

  6. 线上mongodb数据库mLab使用总结

    最近在CNode社区看到有人分享了免费的线上mongodb数据库(容量500M),今天去注册了一下,成功的将线下数据库替换掉了,现在就说一下它的使用和配置需要注意的地方: mLab是一款免费的在线mo ...

  7. mongoDB数据库和Spring MVC的整合

    之前一直用到的项目是Spring MVC+maven+mysql的,最近有些数据需要用到mongoDB数据库,现在做一些总结. 第一步:加载jar.maven配置 <!-- mongodb开始 ...

  8. 【转载】CentOS6.5_X64下安装配置MongoDB数据库

    [转载]CentOS6.5_X64下安装配置MongoDB数据库 2014-05-16 10:07:09|  分类: 默认分类|举报|字号 订阅      下载LOFTER客户端 本文转载自zhm&l ...

  9. 基于C#的MongoDB数据库开发应用(3)--MongoDB数据库的C#开发之异步接口

    在前面的系列博客中,我曾经介绍过,MongoDB数据库的C#驱动已经全面支持异步的处理接口,并且接口的定义几乎是重写了.本篇主要介绍MongoDB数据库的C#驱动的最新接口使用,介绍基于新接口如何实现 ...

  10. 基于C#的MongoDB数据库开发应用(2)--MongoDB数据库的C#开发

    在上篇博客<基于C#的MongoDB数据库开发应用(1)--MongoDB数据库的基础知识和使用>里面,我总结了MongoDB数据库的一些基础信息,并在最后面部分简单介绍了数据库C#驱动的 ...

随机推荐

  1. CE 进程间通信

    WINCE下进程间通信常用的方式有:剪贴板(Clipboard),网络套接字(Socket),WM_COPYDATA消息,共享内存,管道(消息队列),注册表等 剪贴板 //////////////// ...

  2. Opencv-Python 学习

    加载一个灰度图,显示图片,按下’s’键保存后退出,或者按下 ESC 键退出不保存. import numpy as np import cv2 img = cv2.imread('linux.png' ...

  3. 一次失败的Selenium chromedriver切换

    背景 Selenium webdriver一直使用Firefox作为浏览器来跑webtest, 但是最近发现ff有时会报超时的错误,于是想到使用chromedriver来提升稳定性.本想只把.fire ...

  4. AJAX 的简单用法:

    AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术. AJAX 是一种用于创建快速动态网页的技术.通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新.这意味着可以 ...

  5. canvas关于getImageData跨域问题解决方法

    一.问题:在使用html5的canvas是,当用到getImageData方法获取图片信息时,会碰到跨域无法获取的情况,代码如下: document.getElementById("pic& ...

  6. Oracle 物理备份--rman

    Oracle 物理备份--rman 1.直接在服务器,打开命令行,输入: rman target/ 2.配置参数也一同备份 configure controlfile autobackup on; 如 ...

  7. .NET 4.0运行.NET 2.0兼容方法

    需要在相同目录下放一个.config文件,例如xxx.exe,就需要一个xxx.exe.config文件,内容如下: <?xml version="1.0"?> < ...

  8. 解决未能加载文件或程序集“Newtonsoft.Json ...."或它的某一个依赖项。找到的程序集清单定义与程序集引用不匹配。 (异常来自 HRESULT:0x80131040)

    今天遇到了一个比较坑的问题,琢磨了好久... 因为需要引用一个第三方的类库,三方的类库引用的是Newtonsoft.Json.dll 版本7.0.0而我的项目中引用的是Newtonsoft.Json. ...

  9. 汇编语言学习与Makefile入门

    继续开发 ; hello-os ; TAB= ORG 0x7c00 ; 指明程序的装载地址 ; 以下的记述用于标准FAT12格式的软盘 JMP entry DB 0x90 DB "HELLO ...

  10. STM32串口

    状态寄存器USART_SR的复位值为0x00C0H:即 第七位发送寄存器空TXE=1和第六位发送完成TC=1寄存器为空, TC=1表明发送已完成.此时只要使能了发送空和发送完成中断就可进入中断ISR( ...