MongoDB基础知识 01
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的更多相关文章
- Mongodb 笔记01 MongoDB 简介、MongoDB基础知识、启动和停止MongoDB
MongoDB 简介 1. 易于使用:没有固定的模式,根据需要添加和删除字段更加容易 2. 易于扩展:MongoDB的设计采用横向扩展.面向文档的数据模型使它能很容易的再多台服务器之间进行分割.自动处 ...
- MongoDB基础知识 02
MongoDB基础知识 02 6 数据类型 6.1 null : 表示空值或者不存在的字段 {"x":null} 6.2 布尔型 : 布尔类型只有两个值true和false {&q ...
- DataBase MongoDB基础知识记录
MongoDB基础知识记录 一.概念: 讲mongdb就必须提一下nosql,因为mongdb是nosql的代表作: NoSQL(Not Only SQL ),意即“不仅仅是SQL” ,指的是非关系型 ...
- MongoDB基础知识记录
MongoDB基础知识记录 一.概念: 讲mongdb就必须提一下nosql,因为mongdb是nosql的代表作: NoSQL(Not Only SQL ),意即“不仅仅是SQL” ,指的是非关系型 ...
- 常见问题:MongoDB基础知识
常见问题:MongoDB基础知识 ·MongoDB支持哪些平台? ·MongoDB作为托管服务提供吗? ·集合(collection)与表(table)有何不同? ·如何创建数据库(database) ...
- MongoDB 基础知识
一. 基础知识 1. MongoDB是一个文档型的数据库,文档就是一个键值对的有序集合. 例如这样:{"greeting":"hello world"} 2. ...
- AI-图像基础知识-01
目前人工智能Artificial Intelligence主要分为两大分支: 计算机视常见:Computer Vision,简称CV CV主要是研究如何让机器看懂世界的一种技术,通过各种光 ...
- CSS基础知识01
一.CSS基础知识介绍 1.css是cascading style sheet层叠式样式表的简写 2.css小用法 加粗:font-weight:bold; 正常用:norma ...
- python基础知识 01
一.计算机基础知识 计算机有硬件+操作系统+软件应用组成 cpu:人的大脑 内存:人的临时记忆 硬盘:人的永久记忆 操作系统 控制计算机硬件工作的流程 应用程序 安装在操作系统上的软件 二.Pytho ...
随机推荐
- swift 截取字符串
- 如何在swift中实现oc中的分类
在oc中为了增强已有类的功能,我们经常使用分类.使用分类,我们可以在不破坏原有类的结构的前提下,对原有类进行模块化的扩展. 但是在swift中没有分类这种写法了.相对应的是swift中只有扩展(Ext ...
- JPEG 图
多媒体教程 - JPEG 图 JPEG 是在 Web 上使用的主要图像格式之一. 本文讲解 JPEG 图像的概念和特性. 理解图像格式 无论是 HTML 还是 XHTML 都没有规定图像的官方格式.然 ...
- LInkedList集合练习
package com.java.linkedlist; import java.util.LinkedList; /* * LinkedList类的特点:查询速度慢,增删速度快. * LinkedL ...
- Codevs 1010 过河卒 2002年NOIP全国联赛普及组
1010 过河卒 2002年NOIP全国联赛普及组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 传送门 题目描述 Description 如图,A 点有一个过河卒 ...
- ie9以上浏览器input文本框/密码框后面的小叉子/小眼睛问题
找了很久不知什么属性控制的这个东西,经过群友的指点重要找到.
- Deep Belief Network
Deep Belief Network3实例3.1 测试数据按照上例数据,或者新建图片识别数据. 3.2 DBN实例//****************例2(读取固定样本:来源于经典优化算法测试函数S ...
- 支付宝接口使用文档说明 支付宝异步通知(notify_url)与return_url.
支付宝接口使用文档说明 支付宝异步通知(notify_url)与return_url. 现支付宝的通知有两类. A服务器通知,对应的参数为notify_url,支付宝通知使用POST方式 B页面跳转通 ...
- 开启/关闭ubuntu防火墙
LInux原始的防火墙工具iptables由于过于繁琐,所以ubuntu系统默认提供了一个基于iptable之上的防火墙工具ufw.而UFW支持图形界面操作,只需在命令行运行ufw命令即能看到一系列的 ...
- hadoop namenode多次格式化后,导致datanode启动不了
jps hadoop namenode -format dfs directory : /home/hadoop/dfs --data --current/VERSION #Wed Jul :: CS ...