美文网首页跟风舞烟学编程 - 大前端技术Web前端之路技术干货
项目实战(连载):基于Angular2+Mongodb+Node

项目实战(连载):基于Angular2+Mongodb+Node

作者: fwytech | 来源:发表于2017-01-27 15:00 被阅读827次

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

    《项目实战:基于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技术实现的多用户博客系统》正在连载中,明天我将为大家推出【第三章:基于MongoDB的MyBlog数据库设计篇(高级篇)】,欢迎各位继续关注~

        搜索并关注“风舞烟”的简书专栏、头条号、微信公众号、 企鹅媒体平台,你可以定期收到关于简书专栏的最新动态以及IT前沿最新技术的高质量经验文章、视频分享。

      谢谢大家的支持,欢迎大家留言交流。

    相关文章

      网友评论

        本文标题:项目实战(连载):基于Angular2+Mongodb+Node

        本文链接:https://www.haomeiwen.com/subject/wxifittx.html