NodeJS中的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)连接数据库:

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

[javascript]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. var MongoClient = require('mongodb').MongoClient;  
  2. var url = 'mongodb://localhost:27017/myproject';  
  3. MongoClient.connect(url, function(err, db) {  
  4.   console.log("Connected successfully to server");  
  5.   db.createCollection("myCollection", { "capped"true"size": 100000, "max": 5000}, function(err, results){  
  6.     console.log("集合创建成功")  
  7.   })  
  8. });  
(3)在集合中插入文档collection.insertMany()

[javascript]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. var collection = db.collection("myCollection");    //选择某一个集合  
  2. collection.insertMany([{a:1},{b:2},{c:3}],function(err, result){   //插入数据,这里插入了三条数据  
  3.     console.log("插入成功");  
  4. })  
这里插一句,每次执行我们的node代码之后,都可以在数据库中进行结果查看,验证我们的操作。比如这里可以使用db.myCollection.find()来查看我们是否成功写入纪录。

(4)查找文档

查找所有文档:

[javascript]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. var collection = db.collection("myCollection");  
  2. <span style="white-space:pre">  </span>collection.find({}).toArray(function(err, docs){  
  3. <span style="white-space:pre">  </span>console.log(docs);   //其中的docs就是获取到的结果  
  4. });  

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

[javascript]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. collection.find({“a”:1}).toArray(function(err, docs){  
  2. <span style="white-space:pre">  </span>console.log(docs);   //返回复合条件的内容  
  3. });  
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值