MongoDB学习笔记01
MongoDB的设计理念:能从服务器端转移到驱动程序来做的事,就尽量转移。
文档是MongoDB的核心概念。多个键及其关联的值有序的放置在一起便是文档。每种编程语言表示文档的方法不太一样。
文档的键是字符串。除了少数例外情况。键可以使用任意UTF-8字符。键不能含有\0(空字符),这个字符用来表示键的结尾;.与$有特别的意义,只有在特定环境下才能使用;以下划线“_”开头的键是保留的,虽然这个并不是严格要求的。
MongoDB区分类型与大小写。{“foo”:"3"}与{"foo":3} {"foo":3}与{"Foo":3},它们是不同的。
MongoDB不能有重复的键。
集合就是一组文档。如果说MongoDB中的文档类似于关系数据库中的行,那么集合就如同表,多个集合可以组成数据库。集合是无模式的,这意味着一个集合里面的文档可以是各种各样的。我们可以通过名字来标识集合,集合名可以是任意UFT-8字符串,只要满足一下条件:
1. 集合名不能是空字符串
2. 集合名不能含有\0字符,这个字符表示集合名的结尾
3. 集合名不能以"system."开头,这是为系统集合保留的前缀。
4. 用户创建的集合名字不能含有保留字符$。有些驱动程序的确支持在集合名里面包含$,这是因为某些系统生成的 集合中包含该字符。除非你要访问这种创建的集合,否则千万不要在名字里出现$
多个集合可以组成数据库,和集合一样数据库也通过名字来标识,数据库的名可以是满足一下条件的任意UFT-8字符串:
1. 不能是空字符串
2. 不能含有''(空格)、.、$、/、\和\0(空字符)
3. 应全部小写
5. 最多64字节
数据库名最终会变成文件系统里的文件,这也是如此多限制的原因。把数据库的名字放到集合前面,得到就是集合的完全限定名,称为命名空间。命名空间的长度不得超过121字节,在实际使用当中应小于100字节。
MongoDB默认使用27017端口.
启动MongoDB并指定数据保存的位置 bin\mongod.exe --dbpath 数据存储的路径,默认保存在(c:\data\db)
插入数据
读取数据
find会返回集合里面所有的文档,若只想查看一个文档,可以使用findOne。find与findOne可以接受查询文档形式的限定条件。使用find时,shell自动显示最多20个匹配的文档,但可以获取更多文档。
更新数据 删除数据
mongo是MongoDB的shell客户端,是一个内置的JavaScript解释器,它还有一些非JavaScript语法的扩展。
有个了解函数功能的技巧,就是在输入的时候不要输入括号,这样会显示该函数的JavaScript源代码,如想看find的机理或参数:
JavaScript只有在db中找不到指定的属性时,才会将其作为集合返回,当属性与目标集合同名时,可以使用getCollection函数,要查看名称中含有无效JavaScript字符的集合,这个函数也可以派上用场。
ObjectId使用12字节的存储空间,每个字节两位十六进制数字,是一个24位的字符串。这个长长的ObjectId是实际存储数据的两倍长。ObjectId的构成如下:
时间戳精确到秒级别
修改器:$set 如果指定的键不存在则创建它
$unset 删除指定的键
$inc 增加已有键的值,或键不存在时创建一个键,只能作用于整数、长整数或双精度浮点数
$ne与$addToSet 数组中有重复的数据时不会添加
$push 如果指定的键已经存在,会向已有的数组末尾加入一个元素,要是没有就会创建一个新的数组
$each
$pull 会将所有匹配的部分删掉
$pop 从数组任何一端删除元素 {$pop:{key:1}}从数组末尾删除 {$pop:{key:-1}}从数组头部删除
数组的定位修改:通过位置(从0开始)或定位操作符("$")【定位符只更新第一个匹配的元素】
upsert是一个特殊的更新,要没有文档符合更新条件,就会以这个条件和更新文档为基础创建一个新文档,如果找到了匹配的文档,则正常更新。效果如图:
save是一个shell函数,可以在文档不存在时插入,存在时更新,他只有一个参数:文档。要是这个文档含有"_id"键,save会调用upsert,否则会调用插入。
想要知道更新了多少个文档,可以运行getLastError命令
findAndModify命令中每个键对应的值如下:
findAndMondify:集合名
query:查询文档,用来检索文档的条件
sort: 排序结果的条件
update:修改文档,对找到的文档执行更新
remove:布尔类型,表示是否删除文档
new:布尔类型,表示返回的是更新前的文档还是更新后的文档,默认是更新前的文档
“update”与“remove”必须有一个也只能有一个,要是匹配不到文档,这个命令会返回一个错误。相比普通的更新来说,findAndMondify速度要慢一些。
MongoDB中的操作时瞬时完成的,这是因为它们都不需要等待数据库的响应,这并不是异步操作,客户端将文档发送给服务器后就立刻干别的了。
MongoDB学习笔记01的更多相关文章
- MongoDB学习笔记-01 简介、安装
MongoDB简介 MongoDB是一种强大.灵活.可拓展的存储方式.是一个面向文档(相当于"行"的概念)的数据库. 可拓展:通过添加服务器而增加存储量. Windows下安装 版 ...
- MongoDB学习笔记01:入门
MongoDB简介 MongoDB是一个开源.高性能.无模式的文档型数据库,当初的设计就是用于简化开发和方便扩展,是NoSQL数据库产品中的一种.是最 像关系型数据库(MySQL)的非关系型数据库. ...
- MongoDB学习笔记系列
回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助 ...
- 软件测试之loadrunner学习笔记-01事务
loadrunner学习笔记-01事务<转载至网络> 事务又称为Transaction,事务是一个点为了衡量某个action的性能,需要在开始和结束位置插入一个范围,定义这样一个事务. 作 ...
- PHP操作MongoDB学习笔记
<?php/*** PHP操作MongoDB学习笔记*///*************************//** 连接MongoDB数据库 **////*************** ...
- MongoDB 学习笔记(原创)
MongoDB 学习笔记 mongodb 数据库 nosql 一.数据库的基本概念及操作 SQL术语/概念 MongoDB术语/概念 解释/说明 database database 数据库 table ...
- mongoDB 学习笔记纯干货(mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)
最后更新时间:2017-07-13 11:10:49 原始文章链接:http://www.lovebxm.com/2017/07/13/mongodb_primer/ MongoDB - 简介 官网: ...
- MongoDB学习笔记(转)
MongoDB学习笔记(一) MongoDB介绍及安装MongoDB学习笔记(二) 通过samus驱动实现基本数据操作MongoDB学习笔记(三) 在MVC模式下通过Jqgrid表格操作MongoDB ...
- 【转】MongoDB学习笔记(查询)
原文地址 MongoDB学习笔记(查询) 基本查询: 构造查询数据. > db.test.findOne() { "_id" : ObjectId("4fd58ec ...
随机推荐
- silverlight visifire控件图表制作——silverlight 后台方法页面事件
1.返回事件 (1.返回silverlight页面,2.返回web页面) private void button_ClickBack(object sender, RoutedEventArgs e) ...
- silverlight+wcf 获得web参数
可以由wcf直接得到参数 ,具体代码如下: using System;using System.Linq;using System.Runtime.Serialization;using System ...
- Emacs显示行号
在配置.emacs文件中加上 (global-linum-mode t) 启动emacs后按 m-x global-linum-mode 就可以显示行号,但是每次打开emacs,要重新 ...
- HTML5视频
<video>标签用于定义视频. 案例1: <!DOCTYPE html><html><head lang="en"> <me ...
- Dede修改文章默认标题长度,让标题全显示
第一步首先你要进入dedecms后台,系统——系统基本参数——其他选项——文档标题最大长度——在这修改为200或更大(其实200应该是足够了). 第二步进入phpmyadmin,点击dede_arch ...
- Linux下SVN(Subversion)自动启动脚本
在Red Hat Linux中自动运行程序 1.开机启动时自动运行程序 Linux加载后, 它将初始化硬件和设备驱动,然后运行第一个进程init.init根据配置文件继续引导过程,启动其 ...
- hdu 3461 Code Lock
http://acm.hdu.edu.cn/showproblem.php?pid=3461 并差集和幂取模 这道题主要是求不可操作区间. #include <cstdio> #inclu ...
- HDU 3516 Tree Construction (四边形不等式)
题意:给定一些点(xi,yi)(xj,yj)满足:i<j,xi<xj,yi>yj.用下面的连起来,使得所有边的长度最小? 思路:考虑用区间表示,f[i][j]表示将i到j的点连起来的 ...
- LeetCode_Insert Interval
Given a set of non-overlapping intervals, insert a new interval into the intervals (merge if necessa ...
- 转:helloworld:一个完整的WCF案例
原文地址:http://blog.csdn.net/mane_yao/article/details/5852845 WCF的ABC: A代表Address-where(对象在哪里)B代表Bindin ...