PHP8.1.21版本已发布
vue8.1.21版本已发布
jquery8.1.21版本已发布

NodeJS中的MongoDB快速入门详细教程

高洛峰
高洛峰 原创
2016-12-07 10:15:49 1233浏览

mongodb 是一个基于分布式文件存储的数据库。由 c++ 语言编写。旨在为 web 应用提供可扩展的高性能数据存储解决方案。

MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。

一、MongoDB必须理解的概念

1.数据库:每个数据库都有自己的权限和集合。

2.文档:一个键值对。

3.集合:一组文档,即一组键值对。当第一个文档插入时,集合就会被创建。

二、Mac下的MongoDB安装和启动

1.使用brew进行安装:brew install mongodb。

2.建立目录:mkdir -p /data/db。这样建立的是mongodb配置中的默认目录。

3.设置/data/db的权限为可读可写:chown `id -u` /data/db。

4.运行mongod命令,开启服务器。

5.新建一个命令终端,输入mongo,进入mongo命令行工具(mongod命令不能暂停)这样就可以在mongo命令行工具中输入各种mongo命令了。

三、MongoDB命令行的基本操作

1.show dbs:查看数据库

2.show collections:查看当前数据库的集合

3.db.COLLECTION_NAME.find():查看该集合下的所有文档

4.use DATABASE_NAME:使用某个数据库

5.db.COLLECTION_NAME.insert({“key”:”value”,””:””......}):向某个集合中插入文档(注意格式)

6.db.COLLECTION_NAME.find({“a”:1}):查找a值为1的文档

7.db.dropDatabase():删除当前正在use的数据库

四、在Node中使用MongoDB

1.安装

在项目目录下执行命令:npm install mongodb —save-dev

要注意的是,必须先按照上面的要求安装好MongoDB才能正常使用NodeJS中的Mongodb。

2.基本使用

(1)连接数据库:

<span style="font-family: Arial, Helvetica, sans-serif;">var MongoClient = require(‘mongodb&#39;).MongoClient; //引入mongodb</span>
[javascript] view plain copy print?在CODE上查看代码片派生到我的代码片
var url = ‘mongodb://localhost:27017/testProject&#39; //设定连接的url,注意前半部分是mongodb数据库端口等,testProject是要创建的数据库,可自己命名
MongoClient.connect(url, function(err, db){
//…注意其中的db就指定的是当前数据库
})

   

(2)创建集合db.createCollection()

var MongoClient = require(&#39;mongodb&#39;).MongoClient;
var url = &#39;mongodb://localhost:27017/myproject&#39;;
MongoClient.connect(url, function(err, db) {
console.log("Connected successfully to server");
db.createCollection("myCollection", { "capped": true, "size": 100000, "max": 5000}, function(err, results){
console.log("集合创建成功")
})
});

   

(3)在集合中插入文档collection.insertMany()

var collection = db.collection("myCollection"); //选择某一个集合
collection.insertMany([{a:1},{b:2},{c:3}],function(err, result){ //插入数据,这里插入了三条数据
console.log("插入成功");
})

   

这里插一句,每次执行我们的node代码之后,都可以在数据库中进行结果查看,验证我们的操作。比如这里可以使用db.myCollection.find()来查看我们是否成功写入纪录。

(4)查找文档

查找所有文档:

var collection = db.collection("myCollection");
<span style="white-space:pre"> </span>collection.find({}).toArray(function(err, docs){
<span style="white-space:pre"> </span>console.log(docs); //其中的docs就是获取到的结果
});

   

查找符合条件的文档内容:

collection.find({“a”:1}).toArray(function(err, docs){
<span style="white-space:pre"> </span>console.log(docs); //返回复合条件的内容
});

   

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。