我爱编程WEB前端程序开发程序员

MongoDB + Nodejs

2017-06-06  本文已影响0人  恰皮

1. 简介

2. 安装

mongod.exe --dbpath c:\data\db

3. 名词概念

4. 启动数据库服务

命令行切换到MongoDB安装目录下的bin目录,运行命令:

mongod

5. 使用MongoDB后台管理shell

在MongoDB安装目录下的bin目录打开 git bash 窗口,运行以下命令:

./mongo

6. 操作

db
show dbs
use <database>
db.dropDatabase()
mongodb://host:port/<database>
npm install mongodb

代码中:

var MongoClient = require('mongodb').MongoClient;
//连接数据库
MongoClient.connect('mongodb://localhost:27017/<yourDatabaseName>', function(err, database) {
  if(err) {
    throw err;
  }
  db = database;
})

之后db则代表了所连接的数据库。

db.<collection>.find()//查找全部
db.<collection>.find().pretty()//pretty() 会以易读有缩进的方式显示查找结果
db.<collection>.find({"key":"value"}) //按照某个键值对来查找collection中的文档
db.<collection>.find({"key":{$type:num}})//按照指定键的值的数据类型来查找,不同的num代表不同的数据类型

Nodejs中:

//参数基本同上,toArray将查找结果转化为数组,result参数代表查找的结果数组
db.collection('collectionName').find().toArray(function(err,result)) {
//somecode here
db.<collection>.insert({})

Nodejs中:

db.collection('collectionName').insert(data,function(err,record){
//data是插入的数据(json格式)
//record:插入操作成功返回的对象
db.<collection>.remove({})

Nodejs中:

db.collection('collectionName').remove({})
db.<collection>.update({"key":"value"},{$set:{"newKey":"newValue"}},boolean,boolean)
//第一个参数代表查询条件
//第二个参数代表新的键值对;
//第三个参数代表如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入(可选,默认false);
//第四个参数代表是否更新多条(可选,默认false,只更新查找到的第一条)

第二个参数除了$set,还可以是$inc(对键值为数字类型的值进行增减操作),$push(对键值为数组类型的追加一个数组元素)等。
在Nodejs中第三第四个参数需写成对象的形式:

db.collection('test').update(
{"key":"value"},
{$set:{"oneKey":"theValue"}},
{
    upsert:true,
    multi:true
}
db.<collection>.aggregate([{$group:{ _id:"$key", num_total:{$sum:1}}}])
//对_id按照某个key的值聚合,按照sum(求和方式),求和结果保存在num_total键

除了$sum 还可以是 $avg(求平均) $min(求最小值) $max(求最大值)

上一篇下一篇

猜你喜欢

热点阅读