MongoDB基础知识 

1. 文档 

文档是MongoDB中的数据的基本单元,类似于关系型数据库管理系统的行。

文档是键值对的一个有序集。通常包含一个或者多个键值对。

例如:

{”greeting" : "Hello, world!", "foo", 3}

2. 集合(collection)

集合就是一组文档,类似关系型数据库中的一张表。

3. 数据库(database)

多个文档组成集合,多个集合组成数据库。一个MongoDB实例可以承载多个数据库。

MongoDB中保留的有特殊语义的数据库:admin, local, config。

4. 启动MongoDB

运行mongod,启动数据库服务器。

Last login: Fri Aug 22 11:03:36 on ttys001
zhangxindeMacBook-Pro:~ zhangxin$ mongod
mongod --help for help and startup options
2014-08-22T11:51:55.900+0800 [initandlisten] MongoDB starting : pid=596 port=27017 dbpath=/data/db 64-bit host=zhangxindeMacBook-Pro.local
2014-08-22T11:51:55.901+0800 [initandlisten]
2014-08-22T11:51:55.901+0800 [initandlisten] ** WARNING: soft rlimits too low. Number of files is 256, should be at least 1000
2014-08-22T11:51:55.901+0800 [initandlisten] db version v2.6.4
2014-08-22T11:51:55.901+0800 [initandlisten] git version: 3a830be0eb92d772aa855ebb711ac91d658ee910
2014-08-22T11:51:55.901+0800 [initandlisten] build info: Darwin bs-osx108-4 12.5.0 Darwin Kernel Version 12.5.0: Sun Sep 29 13:33:47 PDT 2013; root:xnu-2050.48.12~1/RELEASE_X86_64 x86_64 BOOST_LIB_VERSION=1_49
2014-08-22T11:51:55.901+0800 [initandlisten] allocator: system
2014-08-22T11:51:55.901+0800 [initandlisten] options: {}
2014-08-22T11:51:55.902+0800 [initandlisten] journal dir=/data/db/journal
2014-08-22T11:51:55.902+0800 [initandlisten] recover : no journal files present, no recovery needed
2014-08-22T11:51:55.996+0800 [initandlisten] waiting for connections on port 27017

mongod在没有参数的情况下会使用默认数据目录,/data/db (windows系统中是C:\data\db),如果目录不存在或者不可写,服务器启动会失败。

在mac或者linux下可以用mkdir -p /data/db/ ,确保创建的目录有写权限。

关闭mongod,可用 Ctrl + C来关闭。

5. MongoDB shell 简介

在确保mongod 已经启动的情况下,打开一个新的命令行运行mongo启动shell。

Last login: Fri Aug 22 11:51:24 on ttys001
zhangxindeMacBook-Pro:~ zhangxin$ mongo
MongoDB shell version: 2.6.4
connecting to: test
Server has startup warnings:
2014-08-22T11:51:55.901+0800 [initandlisten]
2014-08-22T11:51:55.901+0800 [initandlisten] ** WARNING: soft rlimits too low. Number of files is 256, should be at least 1000
>

shell是一个功能完备的JavaScript解释器,可运行任何JavaScript程序。

5.1 要查看当前指向哪个数据库,可以使用db命令:

为方便SQL shell的用户,shell还包含了一些非JavaScript语法的扩展。

选择数据库使用use + dbname(数据库名称),再使用db 查看db变量,则发现已经指向了dbname数据库。

Last login: Fri Aug 22 11:51:24 on ttys001
zhangxindeMacBook-Pro:~ zhangxin$ mongo
MongoDB shell version: 2.6.4
connecting to: test
Server has startup warnings:
2014-08-22T11:51:55.901+0800 [initandlisten]
2014-08-22T11:51:55.901+0800 [initandlisten] ** WARNING: soft rlimits too low. Number of files is 256, should be at least 1000
> db
test
> use zhangxindb
switched to db zhangxindb
> db
zhangxindb
>

5.2 shell 中的基本操作

5.2.1 创建

insert 函数可将一个文档添加到集合中。

创建一个名为post的局部变量,这是一个JavaScript对象,用于表示我们的文档。

> post = {"title":"My Blog Post", "content":"Here's my blog post.", "date":new Date() }
{
"title" : "My Blog Post",
"content" : "Here's my blog post.",
"date" : ISODate("2014-08-22T03:53:31.624Z")
}
>

这个对象是一个有效的MongoDB文档,用insert方法保存到blog集合中。

> db.blog.insert(post)
WriteResult({ "nInserted" : 1 }) > db.blog.findOne()
{
"_id" : ObjectId("53f6bee6ef70aed220766a98"),
"title" : "My Blog Post",
"content" : "Here's my blog post.",
"date" : ISODate("2014-08-22T03:53:31.624Z")
}
>

5.2.2 读取

find和findOne()方法可以用于查询集合里的文档。如上图中所示。

5.2.3 更新

使用update修改博客文章。update方法至少接收两个参数,第一个是限定条件,第二个是新的文档。比如:

> post.comments = []
[ ]
> post
{
"title" : "My Blog Post",
"content" : "Here's my blog post.",
"date" : ISODate("2014-08-22T03:53:31.624Z"),
"comments" : [ ]
}
> db.blog.update({title:"My Blog Post"},post)
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.blog.findOne()
{
"_id" : ObjectId("53f6bee6ef70aed220766a98"),
"title" : "My Blog Post",
"content" : "Here's my blog post.",
"date" : ISODate("2014-08-22T03:53:31.624Z"),
"comments" : [ ]
}
>

4. 删除

使用remove方法可将文档从数据库中永久删除。如果没有任何参数,会将集合内所有文档全部删除。

> db.blog.remove({title:"My Blog Post"})
WriteResult({ "nRemoved" : 1 })
> db.blog.findOne()
null

本文适合零基础并且想快速入门的同学,写的非常简略简单就是为了用最短的时间入门,在入门后,再逐步深入,细细挖掘。不适合有基础,或者想慢慢啃的同学,相当于是快餐吧。有错误请不吝赐教。

参考资料:《MongoDB权威指南》

试验环境:mac 64位

MongoDB基础知识 01的更多相关文章

  1. Mongodb 笔记01 MongoDB 简介、MongoDB基础知识、启动和停止MongoDB

    MongoDB 简介 1. 易于使用:没有固定的模式,根据需要添加和删除字段更加容易 2. 易于扩展:MongoDB的设计采用横向扩展.面向文档的数据模型使它能很容易的再多台服务器之间进行分割.自动处 ...

  2. MongoDB基础知识 02

    MongoDB基础知识 02 6 数据类型 6.1 null : 表示空值或者不存在的字段 {"x":null} 6.2 布尔型 : 布尔类型只有两个值true和false {&q ...

  3. DataBase MongoDB基础知识记录

    MongoDB基础知识记录 一.概念: 讲mongdb就必须提一下nosql,因为mongdb是nosql的代表作: NoSQL(Not Only SQL ),意即“不仅仅是SQL” ,指的是非关系型 ...

  4. MongoDB基础知识记录

    MongoDB基础知识记录 一.概念: 讲mongdb就必须提一下nosql,因为mongdb是nosql的代表作: NoSQL(Not Only SQL ),意即“不仅仅是SQL” ,指的是非关系型 ...

  5. 常见问题:MongoDB基础知识

    常见问题:MongoDB基础知识 ·MongoDB支持哪些平台? ·MongoDB作为托管服务提供吗? ·集合(collection)与表(table)有何不同? ·如何创建数据库(database) ...

  6. MongoDB 基础知识

    一. 基础知识 1. MongoDB是一个文档型的数据库,文档就是一个键值对的有序集合. 例如这样:{"greeting":"hello world"} 2. ...

  7. AI-图像基础知识-01

        目前人工智能Artificial Intelligence主要分为两大分支: 计算机视常见:Computer Vision,简称CV   CV主要是研究如何让机器看懂世界的一种技术,通过各种光 ...

  8. CSS基础知识01

    一.CSS基础知识介绍 1.css是cascading style sheet层叠式样式表的简写 2.css小用法 加粗:font-weight:bold;             正常用:norma ...

  9. python基础知识 01

    一.计算机基础知识 计算机有硬件+操作系统+软件应用组成 cpu:人的大脑 内存:人的临时记忆 硬盘:人的永久记忆 操作系统 控制计算机硬件工作的流程 应用程序 安装在操作系统上的软件 二.Pytho ...

随机推荐

  1. centos 彻底卸载mysql

    yum remove mysql mysql-server mysql-libs compat-mysql51rm -rf /var/lib/mysqlrm /etc/my.cnf查看是否还有mysq ...

  2. 2014-11-26----css的简介

    CSS :层叠样式表 cascading style sheets 它的作用是:美化html网页 格式:样式名:值:样式名:值:样式名:值: 注释语法:/* 注释内容 */ 选中代码按TAB,代码左移 ...

  3. java web工程的错误页面的简单配置

    jsp页面,本身服务器也会将该页面翻译成一个servlet页面,所以请求该页面就会有可能出现错误的情况,就会出现下面类似的页面 这样给客户看到并不友好. 1.jsp页面<%@ page %> ...

  4. 什么XSS攻击?PHP防止XSS攻击函数

    什么XSS攻击?PHP防止XSS攻击函数 发布时间: 2013-05-14 浏览次数:22325 分类: PHP教程 XSS 全称为 Cross Site Scripting,用户在表单中有意或无意输 ...

  5. [Linux]Ubuntu下如何将普通用户提升到root权限

    转至:http://jingyan.baidu.com/album/6181c3e0780131152ef153ff.html?picindex=0&qq-pf-to=pcqq.c2c  在u ...

  6. Sharepoint 问题集锦 - 外部列表(external list) - 读取当前用户上下文或用户名作为筛选参数

    在创建外部列表过程中,往往需要添加筛选参数,而较多开发用户,会关心如何在外部列表中,只显示当前用户相关的行.本例子中,我们以任务数据表来做例子,看看如何实现这个需求. 1)数据表tbl_task: t ...

  7. main函数的参数

    一.main的参数 形式:int main(int argc,char *argv[]) 参数argc.argv可以被看做是main函数的形参,argc是整型变量,代表的是参数的个数:argv是指向字 ...

  8. Laravel之路——file缓存修改为redis缓存

    1.Session: 修改.evn文件: SESSION_DRIVER:redis (如果还不行的话,修改config/session.php的driver) 2.缓存修改为redis 注意:使用 L ...

  9. 添加三维动画 demo

    - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typica ...

  10. spring- properties 读取的五种方式

    转至:http://www.cnblogs.com/hafiz/p/5876243.html 方式1.通过context:property-placeholder加载配置文件jdbc.properti ...