第六章 建议学习时间4小时  课程共10章

学习方式:详细阅读,并手动实现相关代码

学习目标:此教程将教会大家 安装Node、搭建服务器、express、mysql、mongodb、编写后台业务逻辑、编写接口,最后完成一个完整的项目后台,预计共10天课程。

数据库


数据库管理结构,一般分为两种:B/S架构   C/S架构。

B/S架构:  Browser/Server,浏览器/服务器模式,即通过浏览器和服务器端的数据库进行交互

C/S架构:  Client/Server,客户端/服务器模式,即通过客户端和服务器的数据库进行交互(我们使用的cmd命令行就可以算是一个客户端)

数据库根据数据结构分为:关系型数据库和非关系型数据库

关系型数据库就如一般很规整的表格,可以根据横向纵向去定位某条数据,如下图

一般的数据库都是关系型数据库 ,如 mySQL,oracle

而非关系型数据库是不能通过横向纵向去定位一条数据,它的结构更像是一个数组里放了很多个json数据,如下图

我们即将学习的mongodb就是非关系型数据库

当下比较火的数据库有:oracle、mySQL、SQL Server

相比这些数据库,mongodb有体积小、能方便快捷的操作,很适合中小型项目的快速开发

而且它可以很好的配置node.js使用  (node.js也可以操作其他的数据库,以后有时间会单独给大家介绍  node.js操作 mySQL)

mongodb安装


1.在官网上下载所需的安装软件

本课程软件下载 链接:http://pan.baidu.com/s/1kVPxBJT 密码:uziu

下载地址:https://www.mongodb.com/download-center#community

根据所需下载相应版本的mongodb安装包

双击安装包后,点击运行

进入到mongodb的安装页面,点击Next进行下一步

选择同意后,点击Next进行下一步

在这里不建议改变安装目录,直接点击Complete进行下一步

点击Install进行安装

等待安装的进度条完成

安装的进度条完成之后,会进入完成页面,点击Finish 就完成了mongodb数据库的安装

完成已上为步骤,就安装成功了

2.检测mongodb是否安装成功,并配置启动命令

在mongodb的安装目录的bin目录下,打开cmd命令行,输入命令 ‘ mongod –help ’出现下图现在这安装成功

设置数据和日志的储存位置和配置mongodb服务

(1)设置数据文件和日志文件储存位置

按自己的爱好设置文件的储存位置,本安装文档的储存位置设置在E盘,目录如下

E:\MongoData

├─data   #MongoDB数据库中的数据的储存位置

└─log    #MongoDB数据库中的日志的储存位置

└─mongodb.log   # MongoDB数据库中的日志的储存文件   (创建方式:创建一个txt,把后缀名改为log)

(2)配置mongodb服务

1/设置mongodb的环境变量

计算机>右键>属性>高级系统设置>环境变量>找到系统变量中的path变量

向path变量的结尾处添加mongodb的安装目录下bin目录的地址(如果原来的path路径后面没有分号,需要添加一个英文的分号再添加mongodb的目录)

如果按本文档安装的mongodb安装目录下bin目录为:

C:\Program Files\MongoDB\Server\3.4\bin

设置完成后依次点击确定,就设置好了mongodb的环境变量了

2/安装mongodb服务

第一步:按照设置的储存位置,修改下面的命令

(ps:如果是按本文档设置的储存位置,不用在做更改)

mongod --logpath "E:\MongoData\log\mongodb.log" --logappend --dbpath "E:\MongoData\data" --directoryperdb --serviceName "MongoDB" --serviceDisplayName "MongoDB" --install

#命令中字段的说明

***  --logpath   指定MongoDB日志文件的存储路径,注意是指定文件不是目录

***  --logappend  使用追加的方式写日志

***  --dbpath   指定数据库数据的存储路径

***  --directoryperdb  每个DB都会新建一个目录

***   --serviceName   指定服务名称

***  --serviceDisplayName  指定服务名称,有多个mongodb服务时执行。

***  --install  指定作为一个Windows服务安装。

第二步:在开始处用管理员身份打开cmd命令行,输入上面第一步修改好的指令回车(ps:一定要以管理员身份运行),(运行完成没有任何错误提示,表示设置成功)

第三步:启动mongodb服务

Net start MongoDB

第四步:关闭mongodb服务

Net stop MongoDB

mongodb操作


管理员身份运行cmd,然后执行 mongo,进入mongodb的命令状态

show dbs 显示当前的数据库,前面两个是自带的,后面两个是我自己创建的(大家第一次使用时只有前面两个数据库)

use 数据名    切换数据库 或 创建新的数据库,  下面我创建了一个名为demo3的数据库

db.createCollection("表名字")   向数据库里面添加表  ,下面 创建了一个表 t1

db 显示当前正在使用的数据库

show tables 显示数据库下的表

再创建一个表 t2

db.表名.drop()  用来从数据库中删除一个表

下图命令删除了 t1表,返回true表示删除成功,再显示表的时候 t1就没有了

db.dropDatabase() 删除当前正在使用的数据库

上图删除了 demo3, 然后显示数据库的时候就没有demo3了

我们重新创建 demo3数据库,然后插入 t1表,然后插入数据

插入数据  db.表名.insert({});   参数中传入json数据,当插入成功以后,系统会自动给数据添加一个独一无二的 _id

使用 db.表名.find()查看数据

查询的时候可以带参数,传入查询的 json即可。下面我们先添加了两条数据(注意:添加的数据name 分别为 zhangsan1  、 zhangsan2,插入不同值方便后面使用),然后实现了带参数和不带参数的查询,结果不同

修改数据 update({修改的条件},{修改器:{修改内容}},第三个参数,第四个参数)

修改器:  $set 修改    $unset删除字段  $inc 当于编程语言中的 “+=”

第三个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。

第四个参数 ,默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。

下面我们来修改一条数据,修改器使用 $set

运行后下面代码后,我们发现 name为zhangsan的数据中的 age被修改为了50  (原来是25)

删除数据的字段,使用 $unset

下面代码删除了 name为zhangsan 的数据的 age属性 (age后面的属性值任意写,因为是删除,写多少都没有意义,但需要写一个json格式)

+=  某条数据,使用$inc

下面代码将 name 为 zhangsan2的数据的  age上叠加10 ,(原来是25,执行以后变成了 35)

Mongo中支持使用 js代码,包括申明变量、循环等等

下面的循环插入10条数据。(虽然提示 nInserted:1 ,但已经插入了10条数据)

查询就可以看到这10条数据了。

查询json支持高级筛选方式

$lt  小于      <

$gt  大于      >

$gte 大于等于  >=

$lte 小于等于  <=

如:

db.t1.find({age:{$lt:5}})   就可以查找age小于5的全部数据

db.t1.find({age:{$lt:5,$gt:1}})   就可以查找age小于5大于1 的全部数据     (多个筛选条件之间使用逗号分隔    )

导入导出

导出:mongoexport可以把一个collection导出成JSON格式或CSV格式的文件。可以通过参数指定导出的数据项,也可以根据指定的条件导出数据。

  、语法:
        mongoexport -d dbname -c collectionname -o file --type json/csv -f field
        参数说明:
            -d :数据库名
            -c :collection名
            -o :输出的文件名
            --type : 输出的格式,默认为json
            -f :输出的字段,如果-type为csv,则需要加上-f "字段名"
    、示例:
        mongoexport -d mongotest -c users -o D:/users.json --type json -f  "_id,user_id,user_name,age,status"

导入:

 、语法:
        mongoimport -d dbname -c collectionname --file filename --headerline --type json/csv -f field
        参数说明:
            -d :数据库名
            -c :collection名
            --type :导入的格式默认json
            -f :导入的字段名
            --headerline :如果导入的格式是csv,则可以使用第一行的标题作为导入的字段
            --file :要导入的文件
 
   、示例:
        mongoimport -d mongotest -c users --file D:/users.json --type json

基本的操作就讲这么多,希望大家把上面的命令都写完。

明天我们讲解:node.js操作mongodb,及操作方法的封装

node.js零基础详细教程(6):mongodb数据库操作的更多相关文章

  1. node.js零基础详细教程(7):node.js操作mongodb,及操作方法的封装

    第七章 建议学习时间4小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...

  2. node.js零基础详细教程(6):mongodb数据库操作 以及导入导出

    第六章 建议学习时间4小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...

  3. node.js零基础详细教程(7.5):mongo可视化工具webstorm插件、nodejs自动重启模块Node Supervisor(修改nodejs后不用再手动命令行启动服务了)

    第七章 建议学习时间4小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...

  4. node.js零基础详细教程(3):npm包管理、git github的使用

    第三章  建议学习时间4小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑 ...

  5. node.js零基础详细教程(4):node.js事件机制、node异步IO操作

    第四章 建议学习时间3小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...

  6. node.js零基础详细教程(5):express 、 路由

    第五章 建议学习时间4小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...

  7. node.js零基础详细教程(2):模块化、fs文件操作模块、http创建服务模块

    第二章  建议学习时间4小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑 ...

  8. node.js零基础详细教程(1):安装+基础概念

    第一章 建议学习时间2小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...

  9. nodejs零基础详细教程2:模块化、fs文件操作模块、http创建服务模块

    第二章  建议学习时间4小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑 ...

随机推荐

  1. CentOS_5.6下使用cmake编译MySQL_5.5.11教程

    注:资料来自网络    Centos 5.6编译安装mysql 5.5.11 2011年06月24日 星期五 05:33 MySQL 最新的版本5.5.11需要cmake编译安装,估计以后的版本也会采 ...

  2. 【算法系列学习】线段树 单点覆盖,区间查询最大值 [kuangbin带你飞]专题七 线段树 B - I Hate It

    https://vjudge.net/contest/66989#overview #include<iostream> #include<cstdio> #include&l ...

  3. 【算法系列学习】[kuangbin带你飞]专题十二 基础DP1 B - Ignatius and the Princess IV

    http://www.cnblogs.com/joeylee97/p/6616039.html 引入一个cnt,输入元素与上一个元素相同,cnt增加,否则cnt减少,当cnt为零时记录输入元素,因为所 ...

  4. 蓝桥杯-逆波兰表达式-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

  5. CAS单点登录(SSO)服务端的部署和配置---连接MySQL进行身份认证

    一.修改系统host,加入 127.0.0.1 server.test.com127.0.0.1 client1.test.com127.0.0.1 client2.test.com 二.安装grad ...

  6. Lucene5.5.4入门以及基于Lucene实现博客搜索功能

    前言 一直以来个人博客的搜索功能很蹩脚,只是自己简单用数据库的like %keyword%来实现的,所以导致经常搜不到想要找的内容,而且高亮显示.摘要截取等也不好实现,所以决定采用Lucene改写博客 ...

  7. Hush Framework框架配置

    在写这篇文章的时候,楼主已经饿的不行了,因为我从3点开始就在折腾Hush Framework,走了很多弯路,打铁要趁热,先把基本的过程记录下来,留待以后翻阅,同时记录其中容易走弯路的地方,特别是对于一 ...

  8. PAT1030 Travel Plan (30)---DFS

    (一)题意 题目链接:https://www.patest.cn/contests/pat-a-practise/1030 1030. Travel Plan (30) A traveler's ma ...

  9. MFC教程

    MFC教程 还有VS2015的视频教程 试看教程地址:http://dwz.cn/4PcfPk免费下载地址:http://dwz.cn/mfc888 一.VS2010/MFC编程入门教程之目录 第一部 ...

  10. JS执行效率与性能提升方案

    如果是追加字符串,最好使用s+=anotherStr操作,而不是要使用s=s+anotherStr.如果要连接多个字符串,应该少使用+=,如 s+=a;s+=b;s+=c;应该写成s+=a + b + ...