MongoDB概述&语法
Nosql DB
这是一个非关系型数据库。 通常我们的数据库有三类: 关系型数据库(RDBMS),联机分析处理数据库(OLAP),和菲关系型数据库(NoSql)。
MongoDB属于第三种,而且是一种基于文档的(document oriented)数据库。
优劣势
优势: 查询性能,在都没有建立索引的时候,明显快于MySql。 都建立了索引后,不慢于MySql。
劣势: 不支持事务。因此如果对于事务要求很高的情形,不适用这个数据库。
概念&语法
概念
collection:集合,等于关系型数据库中的table。
document:文档对象,等同于关系型数据库table中的一行记录。
field: 键值对,等同于关系型数据库中table的一个column
database:这个没啥区别。
数据在MongoDB中是以BSON的格式存储的,所谓BSON就是binary json, 也就是二进制的json数据。
语法
属性:javascript语法。
显示数据库: show dbs
使用数据库: use db (备注:这样子就好了,db不存在,则“新建”一个出来,不会报错,事实是:直到存储docuemnt对象时才创建collection和数据库)
查询数据表:db.getCollectionNames() / show collections
数据库统计信息:db.stats()
插入记录: db.your_collection.insert(json表达式) (备注:可以将关联的对象通过json表达式存储在一个document里面---如下图图2中的标注3所示,这个跟关系型数据库不同)
更新记录: db.your_collection.update(json表达式查询用, {$set:json表达式更新用}, 不存在是否插入记录-默认False, 是否更新所有数据-默认False-只更新第一条)
db.your_collection.save(json表达式) : 实际上是插入和更新操作的合并,记录不存在则insert(根据_id字段判断),存在则update。
删除记录: db.your_collection.remove(json表达式)
以上指令演示如下图所示:
图1
查询记录:db.your_collection.find({键值对},{需要显示/隐藏的字段的键值对})/findOne({键值对},{需要显示/隐藏的字段的键值对})
注意:a) find返回的是一个cursor对象(游标对象), 而findOne返回的是一个document(一条记录)。
find的结果可以用forEach(printjson)格式化,如下图(图中标注1)所示:
图2
b).findOne,对于有多条记录,则只返回第一条记录(最旧的那条).
c). 第二个参数:{需要显示/隐藏的字段的键值对}, 要么设为白名单,即允许显示哪些字段 ,如{ field1:1, field2:1,...},
要么设置为黑名单,即指定哪些字段不显示,如 {field1:0 , field2:0,....}
不能混用,例如 {field1:1, field2:0},这个是不受支持的。
但对于_id字段例外,这个字段可以混用。
d). 由于一个document中可能存储多级对象,引用子对象可以像js中一样用点号(.)。
例如,已知,user对应的document中存储了name字段,这个字段是一个json对象(另外一张表--在关系型数据库中),如下
{ "_id":ObjectId("a2349723424adfa14"),
"name":{"first":"John","last":"Smith"}
.... }
那么,如果要查询名为john的人,可以这样写js
db.user.find({'name.first':'John'})
其实,这样写也是ok的:
db.user.find({name:{first:'John'}})
e). 范式(normalization)与反范式(de-normalization)
通常把所有的数据存储在一个document里面,这个叫做de-normalization,即用冗余换取读取的性能。这通常使用于读数据比较多的情形,比如cms系统。
如果写数据会比较多,最好normalization一下,即通过第一,第二,第三范式将数据表(collection)重新设计。
mongodb是支持normalization的,通过_id实现(图2中标注2),_id采用了一个特殊的算法,考虑到机器,数据库,collection,时间等因素,将其综合编码到_id中,以保证数据的唯一性。
在normalization后的数据库中,通过link(链接),指向其他document。
例如,book对象可以有author对象的链接,如下:
{"_id":ObjectId("book_id1123132"),
"name":"MongoDB 30分钟精通",
"author_id": ObjectId("author_id_say_tommy"),
...
}
author document对象:
{
"_id": ObjectId("author_id_say_tommy"),
"name":"Tommy",
...
}
这个就是分离了冗余数据,从而有利于update数据操作。
f). 模糊查询
大于: $gt, 小于: $lt, 小于等于: $lte, 大于等于: $gte,
例如,找出所有的被收藏50次以上的链接,可以这样写
db.links.find({favourites:{$gt:50}})
条件:且、或
且,这个是默认的,如果要找出50~100区间的记录,则可以这样写: db.links.find({favourites:{>:50, <:100}})
或,$or,这个操作有点特殊,格式如下:
db.your_collection.find({$or:[{条件1},{条件2},{条件3},...]})
其中条件是键值对表达式,表达式中可以有多个键值对(之前且的关系),条件之间是或的关系。
还有个极端的$nor操作符,取的记录不要符合其中的任何一个条件。对比之下$or的符合其中任何一个条件就ok。
画蛇添足的,还有一个&and操作符,实现且操作的,和$or差不多。
$in , $nin , $all
$in 跟sql的in差不多, $nin根sql的not in差不多, $all,通常用于list,需要list完全匹配。
例子:
db.users.find({'name.first':{$in:['John','David']}})
$ne
相当于sql的 !=
例子:
db.users.find({age:{$ne:30}})
$exists操作符
由于mongodb的document在存放时,对于没有赋值的field,是不保存的。这点和关系型数据库不同,mysql即使某个栏位没有被赋值,那个栏位还在。
因此,可以用这个来过滤出存在或者不存在某些栏位的document。
例如: 找出有维护了age信息的user可以这样写: db.users.find({age:{$exists:true}})
反之,则这样写:db.users.find({age:{$exists:false}})
$not 操作符(取反,用法和$or类似),需要配合其他操作符使用,建议少用,能不用就不用,性能貌似不好。
格式:
db.your_collection.find({field:{$not:{$op:val}}})
$elemMath ,用于匹配含有json的list中的某个json元素的表达式。详细请参考官方: www.mongodb.org
$where
基本上,这个操作符可以做一切你想做的事情,包括替代上面的所有操作符。但是性能不好。当你发现上面的操作符都没法满足你特定要求的时候,可以考虑这个。
语法: db.your_collection.find({$where:f,$otherop:otherval}),其中f是表达式或者js函数。没有其他操作符的情况下,也可以这样写:
db.your_collection.find(f)
例子:找出所有名字含有jo的用户(作为like操作符缺失的弥补)
db.users.find('this.name.first.indexOf("jo")>-1')
转载请注明:本文来自:http://www.cnblogs.com/Tommy-Yu/p/3995997.html,谢谢!
MongoDB概述&语法的更多相关文章
- MongoDB笔记(一)MongoDB概述和安装
概述 关键词:关系数据库.非关系数据库 关系数据库: 关系数据库,是建立在关系数据库模型基础上的数据库,借助于集合代数等概念和方法来处理数据库中的数据.目前主流的关系数据库有oracle.SQL.ac ...
- MongoDB查询语法
mongoDb是非关系型数据库,用习惯了mssql,mysql等数据库的需要转换一下思维 mongoDb存的是与js的json结构一样的文档,表中的每一条记录都可以结构不同 1,大于,小于,大于等于, ...
- Redis,MemCached,MongoDB 概述
调研项目主要有Redis. MemCached. MongoDB,以及Amazon的DynamoDB Redis 是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key- ...
- 非关系型数据库mongodb的语法模式
from pymongo import MongoClient #连接 conn = MongoClient() #进入数据库 db = conn.edianzu #连接mydb数据库,没有则自动创建 ...
- MongoDB 基本语法笔记
MongoDB常识 MongoDB Shell是MongoDB自带的交互式Javascript shell,所以可直接执行JS脚本,用来对MongoDB进行操作和管理的交互式环境. ObjectId: ...
- flask_ Mongodb 的语法-排序
MOngoDB的排序是挺有用的 ,跟MySQL有明显的区别 .. 它的原生语法的第一个参数为条件限定,第二个参数为排序字段 db.news.find({},{'_id':1}) #1是升序 ...
- mongodb 基础语法
参考原文:菜鸟教程 目录 一.数据库二.文档三.索引四.聚合 一.数据库 show dbs -- 查看所有数据库 use DATABASE_NAME -- 如果数据库不存在,则创建数据库,否则切换到指 ...
- MongoDB 查询语法
转载 http://blog.163.com/lgh_2002/blog/static/440175262012052116455/ 详见官方的手册:http://www.mongodb.org/di ...
- mongodb c#语法基础
这里采用的是mongoDB官网推荐使用.net驱动: http://mongodb.github.io/mongo-csharp-driver/2.0/getting_started/quick_to ...
随机推荐
- Linq之Lambda表达式初步认识
目录 写在前面 匿名方法 一个例子 Lambda 定义 一个例子 总结 参考文章 写在前面 元旦三天在家闲着无事,就看了看Linq的相关内容,也准备系统的学习一下,作为学习Linq的前奏,还是先得说说 ...
- (转)Java并发编程:volatile关键字解析
转:http://www.cnblogs.com/dolphin0520/p/3920373.html Java并发编程:volatile关键字解析 volatile这个关键字可能很多朋友都听说过,或 ...
- Spring配置文件详解:<context:annotation-config/>和<context:component-scan base-package=""/>和<mvc:annotation-driven />
<context:annotation-config/> 在基于主机方式配置Spring时,Spring配置文件applicationContext.xml,你可能会见<contex ...
- Oracle 索引
索引是建立在数据库表中的某些列的上面,是与表关联的,可提供快速访问数据方式,但会影响增删改的效率:常用类型(按逻辑分类):单列索引和组合索引.唯一索引和非唯一索引. 什么时候要创建索引 (1)在经常需 ...
- Vijos p1892 树上的最大匹配 树形DP+计数 被卡常我有特殊技巧heheda
https://vijos.org/p/1892 此题需要手动开栈: <<; //256MB char *p=(char*)malloc(size)+size; __asm__(" ...
- 从ICLassFactory 为 CLSID的COM组建创建实例失败:c001f011
在sqlserver创建计划任务的时候,保存时出现:“从ICLassFactory 为 CLSID的COM组建创建实例失败:c001f011”. 解决方法:在运行sqlserver时,使用“以管理员身 ...
- Linux 基础网络设置
一.查看以及测试网络 查看及测试网络配置是管理Linux网络服务的第一步,本节将学习Linux系统中的网络查看以及测试命令.其中讲解的大多数命令以普通用户权限就可以完成操作,但是普通用户在执行&quo ...
- IOS基础之 (十一) 内存管理 ARC
一 内存管理 1. set 方法内存管理的相关参数 retain: release旧值,retain新值(值适用于OC对象) assign:直接赋值(set方法默认,适用于非OC对象类型,即基本数据类 ...
- POJ2392Space Elevator(贪心+背包)
Space Elevator Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 9970 Accepted: 4738 De ...
- MySQL------如何安装mysql-connector-java-5.1.38.zip
下载地址:http://dev.mysql.com/downloads/connector/j/ 安装mysql-connector-java-5.1.38.zip:1.解压文件->把里面的my ...