本章主要讲什么(一句话)?

 

《项目实战:基于Angular2+Mongodb+Node技术实现的多用户博客系统教程(2)》

-- 基于MongoDB的MyBlog数据库知识技术储备(上)

一、前言

在开始正式讲解本系统前,我们可能需要给大家准备一些基本知识的储备,本节我们将会给大家快速的补充一下本系统必须的MongoDB部分的知识点,具体包括以下内容:

了解什么是MongoDB以及MongoDB的特性

掌握MongoDB最常见的用法

二、认识非关系型数据库MongoDB

2.1、MongoDB简介

官方定义:MongoDB 是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。

通俗解释: Mongo DB ,是目前在IT行业非常流行的一种非关系型数据库(NoSql),其灵活的数据存储方式,备受当前IT从业人员的青睐。Mongo DB很好的实现了面向对象的思想(OO思想),在Mongo DB中 每一条记录都是一个Document对象。Mongo DB最大的优势在于所有的数据持久操作都无需开发人员手动编写SQL语句,直接调用方法就可以轻松的实现CRUD操作。

特点

1、MongoDB是基于文档的数据库

2、是介于关系型数据库和非关系型数据库之间的产品(最像关系性数据库的NoSQL)

3、支持类似json的bson格式,数据结构非常松散

官网地址:http://www.mongodb.org/ 百度百科:http://baike.baidu.com/subview/3385614/9338179.htm

2.2、MongoDB优缺点

优点:弱一致性文档结构的存储方式内置GridFS(分布式文件系统)

缺点:不支持事务空间占用大

2.3、主要适用场合

其主要场景如下:

1)网站实时数据处理。它非常适合实时的插入、更新与查询,并具备网站实时数据存储所需的复制及高度伸缩性。

2)缓存。由于性能很高,它适合作为信息基础设施的缓存层。在系统重启之后,由它搭建的持久化缓存层可以避免下层的数据源过载。

3)高伸缩性的场景。非常适合由数十或数百台服务器组成的数据库,它的路线图中已经包含对MapReduce引擎的内置支持。

不适用的场景如下:

1)要求高度事务性的系统。

2)传统的商业智能应用。

3)复杂的跨文档(表)级联查询。

三、MongoDB安装配置

1)在官网直接下载安装包,下载地址:http://www.mongodb.org/downloads

2)安装非常的简单只要,解压或者安装就可以。这取决于你下载的是msi安装包

是zip压缩包。

如果是zip的压缩包。直接解压,解压后,放在D:/MongoDB目录下。为了命令行的方便,可以把D:/MongoDB/bin加到系统环境变量的path中。

如果是msi安装包。基本默认安装下一步下一步即可,注意你的安装路径。

3)测试是否安装成功

D:\>mongod  --dbpath  D:/MongoDB/data

Sun Oct 24 15:07:05 MongoDB starting : pid=2472 port=27017

dbpath=D:/MongoDB/data 32-bit

** NOTE: This is a development version (1.7.1) of MongoDB.

。。。。

Sun Oct 24 15:07:05 [websvr] web admin interface listening on port 28017

由于是开发版,上面就有个警告,没关系,忽略它。

最后两行说明的数据库端口和Web端口,分别是27017和28017,在浏览器中打开http://localhost:27017,可以看到其相关的一些信息。

这样说明安装成功。

四、MongoDB基本用法

4.1、创建库

use 命令

MongoDB use DATABASE_NAME 用于创建数据库。该命令将创建一个新的数据库,如果它不存在,否则将返回现有的数据库。

语法:

use DATABASE 语句的基本语法如下:

use DATABASE_NAME

示例:

如果想创建一个数据库名称 , 那么 use DATABASE 语句如下:

>use testDB

switched to db testDB

要检查当前选择的数据库使用命令 db

>db

testDB

PS:

前提1 - mongodb安装在d:/mongodb目录下

前提2 - 已经将d:/mongdb/bin配置在windows环境变量的path路径中

前提3 – 在d:/mongodb/目录下新建一data文件夹

前提4 – 运行cmd命令,在命令行中健入如下命令:

> mongod --dbpath D:/MongoDB/data

运行如下图所示:

 

说明mongodb服务器启动在:127.0.0.1:385979端口处监听请求!

重新打开一新的控制台:

并健入如下命令:mongo

 

用于连结服务器,默认连结他的默认数据库test

说明创建数据库成功!

查看数据库:

控制台中健入如下命令:show dbs,注意此时显示的只会有local数据库,却没有testDB,原因是因此时数据库并没有集合(数据),所以此时只有逻辑数据库产生,并没有产真正意义上的物理数据,必须调用db.createCollection("集合名")后,具体的后面会讲到,再次运行: show dbs命令,才能看到testDB数据库,另外,mongodb的命令是区分大小写的,这一点也是要注意!

4.2、删除库

dropDatabase()方法

MongoDB db.dropDatabase() 命令是用来删除一个现有的数据库。

语法:

dropDatabase() 命令的基本语法如下:

> db.dropDatabase()

这将删除选定的数据库。如果还没有选择任何数据库,然后它会删除默认的 ' test' 数据库

示例:

首先,检查列表数据库通过使用命令 show dbs

>show dbs

local      0.78125GB

mydb       0.23012GB

test       0.23012GB

>

如果想删除新数据库 ,  那么 dropDatabase() 命令如下:

>use mydb

switched to db mydb

>db.dropDatabase()

>{ "dropped" : "mydb", "ok" : 1 }

>

现在检查的数据库列表:

>show dbs

local      0.78125GB

test       0.23012GB

>

4.3、创建集合

在mongodb里面,没有表的概念,集合(collections)就相当于传统数据库中的表。

createCollection() 方法

MongoDB db.createCollection(name, options) 是用来创建集合.

语法:

基本的 createCollection() 命令语法如下:

db.createCollection(name, options)

 

在命令中, name 是要创建的集合的名称. Options 是一个文件,用于指定配置的集合

 

选项参数是可选的,所以只需要到指定的集合名称。以下是可以使用的选项列表:

例子:

createCollection() 方法不使用选项的基本语法如下:

>use test

switched to db test

>db.createCollection("mycollection")

{ "ok" : 1 }

>

可以检查通过使用创建的集合命令 show collections

>show collections

mycollection

system.indexes

下面的例子显示了几个重要的选项 createCollection()方法的语法:

>db.createCollection("mycol", { capped : true, autoIndexID : true, size : 6142800, max : 10000 } )

{ "ok" : 1 }

>

在MongoDB中,不需要创建集合。当插入一些文件 MongoDB 自动创建的集合。

>db.newdb.insert({"name" : "yiibai"})

>show collections

mycol

mycollection

system.indexes

newdb

>

4.4、删除集合

drop() 方法

MongoDB 的 db.collection.drop() 是用来从数据库中删除一个集合。

语法:

drop() 命令的基本语法如下

db.COLLECTION_NAME.drop()

示例:

首先,检查可用的集合在数据库 mydb

>use mydb

switched to db mydb

>show collections

mycol

mycollection

system.indexes

yiibai

>

现在删除集合名称为 mycollection

>db.mycollection.drop()

true

>

再次检查到数据库中的集合列表

>show collections

mycol

system.indexes

yiibai

>

drop() 方法将返回 true,如果选择成功收集被丢弃,否则将返回 false

五、后述

下章剧透:

《项目实战:基于Angular2+Mongodb+Node技术实现的多用户博客系统教程(3)》

-- 基于MongoDB的MyBlog数据库知识技术储备(下)

 

项目实战(连载):基于Angular2+Mongodb+Node技术实现的多用户博客系统教程(2)的更多相关文章

  1. 【ASP.NET实战教程】基于ASP.NET技术下多用户博客系统全程实战开发(NNblog)

    岁末主推:牛牛老师主讲,多用户博客系统,基于ASP.NET技术,年后将带来移动业务平台项目项目目标: 打造个性品牌Blogo,定制多用户博客 为每一个博客用户提供个性化的 blogo解决方案,打造精品 ...

  2. 基于SAE+CodeIgniter3.0+管理端angularjs+前台amazeui的多用户博客系统V1.0--系统设计(一)

    开发环境: 服务器系统:CentOS-6.x web服务器:Apache-2.2.x php版本:PHP-5.3.x 开发工具:sublime text 3 ,谷歌浏览器 数据库查询工具:phpmya ...

  3. 云计算Docker全面项目实战(Maven+Jenkins、日志管理ELK、WordPress博客镜像)

    2013年,云计算领域从此多了一个名词“Docker”.以轻量著称,更好的去解决应用打包和部署.之前我们一直在构建Iaas,但通过Iaas去实现统一功  能还是相当复杂得,并且维护复杂.将特殊性封装到 ...

  4. 基于 Express + MySQL + Redis 搭建多用户博客系统

    1. 项目地址 https://github.com/caochangkui/node-express-koa2-project/tree/master/blog-express 2. 项目实现 Ex ...

  5. 基于react全家桶+antd-design+webpack2+node+express+mongodb开发的前后台博客系统

    很久没更新博客,最近也有点忙,然后业余时间搞了一个比较完整基于react全家桶+antd-design+webpack2+node+express+mongodb开发的前后台博客系统的流程系统,希望对 ...

  6. react + node + express + ant + mongodb 的简洁兼时尚的博客网站

    前言 此项目是用于构建博客网站的,由三部分组成,包含前台展示.管理后台和后端. 此项目是基于 react + node + express + ant + mongodb 的,项目已经开源,项目地址在 ...

  7. vue+node+mongodb前后端分离博客系统

    感悟 历时两个多月,终于利用工作之余完成了这个项目的1.0版本,为什么要写这个项目?其实基于vuejs+nodejs构建的开源博客系统有很多,但是大多数不支持服务端渲染,也不支持动态标题,只是做到了前 ...

  8. 一个 Vue + Node + MongoDB 博客系统

    源码 耗时半载(半个月)的大项目终于完成了.这是一个博客系统,使用 Vue 做前端框架,Node + express 做后端,数据库使用的是 MongoDB.实现了用户注册.用户登录.博客管理(文章的 ...

  9. Vue、Node全栈项目~面向小白的博客系统~

    个人博客系统 前言 ❝ 代码质量问题轻点喷(去年才学的前端),有啥建议欢迎联系我,联系方式见最下方,感谢! 页面有啥bug也可以反馈给我,感谢! 这是一套包含前后端代码的个人博客系统,欢迎各位提出建议 ...

随机推荐

  1. Docker 新网络 overlay 网络

    Overlay网络是指在不改变现有网络基础设施的前提下,通过某种约定通信协议,把二层报文封装在IP报文之上的新的数据格式. 这样不但能够充分利用成熟的IP路由协议进程数据分发,而且在Overlay技术 ...

  2. hibernate---一对一双向外键关联 (重要)

    husband--wife: one to one 双向外键关联: 主导方: @OneToOne @JoinColumn(name="wifeId") 被主导方: @OneToOn ...

  3. spring加载过程中jar包加载不了,解决方法

    当我们在开发spring项目时,一般会将jar包放到webInf/lib下,这样是myeclipse自动将jar包加载到tomcat中webapps下,但是当我们新建一个lib文件夹的情况下,我们ad ...

  4. 简单的字符串比较题 POJ 1936

    Description You have devised a new encryption technique which encodes a message by inserting between ...

  5. CentOS 6.X x64 编译安装 Countly

    CentOS 6.X  x64 编译安装Countly 安装所需的软件 yum -y install supervisor ImageMagick sendmail 1. 安装 node.js wge ...

  6. input有许多,点击按钮使用form传递文本框的值

    input有许多,点击按钮使用form传递文本框的值 <form name="form1" method="post" action="< ...

  7. TCP协议和UDP协议的区别

    1. TCP协议面向连接. UDP协议面向非连接 (有无链接)2. TCP协议传输速度慢. UDP协议传输速度快 (传输速度)3. TCP协议保证数据顺序. UDP协议不保证 (数据的有序性. 在IP ...

  8. Chapter5 – 碰撞检测

    主人公能够放子弹了,虽然子弹看起来很美,但是怎么样来打到妖怪? 在这一章我们介绍一下最简单的碰撞检测方法去实现它. 首先第一个,我们有必要保存每个妖怪和子弹的指针,来够追踪他们的位置. 在这个游戏中我 ...

  9. IOS开发中使用CNContact\CNMutableContact 对通讯录增删改查

    IOS开发中使用CNContact\CNMutableContact 对通讯录增删改查 首先当然是把CNcontact包含在工程中: @import Contacts; 1.下面是增加联系人的程序段: ...

  10. thinkphp ,进行关联模型的时候出现的问题,版本是3.2

    看的后盾网络视频,里面操作的是3.1. 我用的是onethink,基于3.2. 在关联模式的操作时.主要是user role  role_user  3个张表 视频中可以操作,但是本地操作出现问题. ...