mongoDB数据库
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数据库的更多相关文章
- Mongodb数据库学习系列————(一)Mongodb数据库主从复制的搭建
Mongodb数据库主从复制的搭建 Writeby:lipeng date:2014-10-22 最近项目上用到了位置查询,在网上 ...
- 基于C#的MongoDB数据库开发应用(4)--Redis的安装及使用
在前面介绍了三篇关于MongoDB数据库的开发使用文章,严格来讲这个不能归类于MongoDB数据库开发,不过Redis又有着和MongoDB数据库非常密切的关系,它们两者很接近,Redis主要是内存中 ...
- FineReport如何连接和使用MongoDB数据库
随着NoSQL数据库越来越流行,MongoDB数据库作为NoSQL数据库中的领头羊,使用也越来越广泛.为此,FineReport V8.0版本提供了数据连接和数据集接口,可以通过开发一款可以连接和使用 ...
- python操作mongodb数据库
一.MongoDB 数据库操作 连接数据库 import pymongo conn = pymongo.Connection() # 连接本机数据库 conn = pymongo.Connection ...
- NoSql 中Mongodb数据库的使用
1.NoSql数据库简介 2.MongoDB数据库的简介 3.MongoDB下Windows下的安装
- 线上mongodb数据库mLab使用总结
最近在CNode社区看到有人分享了免费的线上mongodb数据库(容量500M),今天去注册了一下,成功的将线下数据库替换掉了,现在就说一下它的使用和配置需要注意的地方: mLab是一款免费的在线mo ...
- mongoDB数据库和Spring MVC的整合
之前一直用到的项目是Spring MVC+maven+mysql的,最近有些数据需要用到mongoDB数据库,现在做一些总结. 第一步:加载jar.maven配置 <!-- mongodb开始 ...
- 【转载】CentOS6.5_X64下安装配置MongoDB数据库
[转载]CentOS6.5_X64下安装配置MongoDB数据库 2014-05-16 10:07:09| 分类: 默认分类|举报|字号 订阅 下载LOFTER客户端 本文转载自zhm&l ...
- 基于C#的MongoDB数据库开发应用(3)--MongoDB数据库的C#开发之异步接口
在前面的系列博客中,我曾经介绍过,MongoDB数据库的C#驱动已经全面支持异步的处理接口,并且接口的定义几乎是重写了.本篇主要介绍MongoDB数据库的C#驱动的最新接口使用,介绍基于新接口如何实现 ...
- 基于C#的MongoDB数据库开发应用(2)--MongoDB数据库的C#开发
在上篇博客<基于C#的MongoDB数据库开发应用(1)--MongoDB数据库的基础知识和使用>里面,我总结了MongoDB数据库的一些基础信息,并在最后面部分简单介绍了数据库C#驱动的 ...
随机推荐
- ✡ leetcode 170. Two Sum III - Data structure design 设计two sum模式 --------- java
Design and implement a TwoSum class. It should support the following operations: add and find. add - ...
- Python2.7.12开发环境构建(自动补全)
一.安装readline-devel包 Python的编译安装依赖于这个包 yum -y install readline-devel 二.安装Python2.7.12 Python官方网站(到此处下 ...
- Apache+PHP+MySQL
Apache:是一种web服务器(与IIS类同)PHP:全称为Hypertext Preprocessor.PHP是一种HTML 内嵌式的语言,是一种网站(网页)开发语言(与ASP.JSP..NET等 ...
- HDU-2296 Ring(AC自动机+DP)
题目大意:给出的m个字符串都有一个权值.用小写字母构造一个长度不超过n的字符串S,如果S包含子串s,则S获取s的权值.输出具有最大权值的最小字符串S. 题目分析:先建立AC自动机.定义状态dp(ste ...
- 05_动手动脑之String.equals()方法的实现代码
Question: 请查看String.equals()方法的实现代码,注意学习其实现方法. Answer: java中的String.equals()方法的实现代码: equals()法是根类Obj ...
- 解决java使用https协议请求出现证书不信任问题(PKIX path building failed)
解决https请求时出现pkix path building fail错误 方法 将submail.cer 安全证书导入到java中的cacerts证书库 (sumail是我从https://api. ...
- 利用IIS管理器模拟CDN
CDN(Content Delivery Network,内容分发网络).其含义,在百度百科上是这么写的:CDN 是构建在数据网络上的一种分布式的内容分发网.CDN 的作用是采用流媒体服务器集群技术, ...
- IOS零碎技术整理(3)-获取wifi列表
1. 该功能实现基于MobileApple80211框架来进行开发,而目前该框架成为了私有框架,其中的API均为私有API. 如果使用这些API可能导致应用不能上app store或者ios版本升 ...
- 对c语言中malloc和free函数的理解
最近在复习c语言的时候再次用到了malloc函数和free函数,此处着讲解一下自己对这两个函数的理解和认识. 一. malloc函数和free函数的基本概念和基本的用法 对于malloc函数: 1. ...
- 用HTML实现凸(凹)起的立体效果的表格
视觉效果如下: 实现这个效果主要用到的是<table>标签的bordercolorlight和bordercolordark两个属性.不过在测试的过程中,我发现有的浏览器不支持这两个属性, ...