mongod
(此前须要安装了mongo数据库,并建立过mongodb的目录:$ mkdir -p /data/db)node
启动mongodb后,可使用mongo命令行来操做数据库,或使用Robomongo这样的GUI客户端。sql
使用一个数据库:(mongodb不须要预先建立数据库,当给一个数据库写入内容时会自动建立)mongodb
$ use mytest
插入数据:(给mytest数据库下的users集合插入一条文档)数据库
$ db.users.insert({"username": "nuanfeng"})
而后能够查看数据库和集合:express
$ show dbs
$ show collections
查看users集合中的全部文档:npm
$ db.users.find()
再添加一条数据:(mongodb是无模式的,因此能够添加不一样格式的数据)json
$ db.users.insert({"username": "Zoe", "group": "reporter"})
再用db.users.find()查看,以下:浏览器
查看数据的数量:安全
$ db.users.find().count()
根据id查询数据:服务器
$ db.users.find({"_id": ObjectId("584bc73ea635e489676cf5db")})
更新数据: (匹配到的第一条)
$ db.users.update({"username": "Zoe"}, {$set: {"group": "writer"}})
更新数据: (匹配到的全部)
$ db.users.update({"username": "Zoe"}, {$set: {"group": "writer"}}, {multi: true})
用save()也能够修改数据:(必须根据‘_id’,会直接替换掉原来的数据)
db.users.save({"_id": ObjectId("584bc73ea635e489676cf5db"), "group": "reporter"})
删除知足条件的全部:
$ db.users.remove({"group": "reporter"});
删除知足条件的第一条:
$ db.users.remove({"group": "reporter"}, true);
删除集合中的全部文档:
$ db.users.remove({})
删除整个集合(全部文档和索引)
$ db.users.drop()
Mongoose是将nodejs的对象和MongoDB中的文档对应的一个模块。
Mongoose既支持强模式,也支持无模式。
安装mongoose:
$ npm install mongoose
先看一下最终的目录结构:
连接的格式:(也能够省略用户名、密码、端口号)
var uri = 'mongodb://username:password@hostname:port/databasename' mongoose.connect(uri);
Model使nodejs对象和MongoDB中的文档相对应,Schema实现了Model的数据类型和结构的定义,从而在无模式的MongoDB中实现了模式化的存储。
model.js
/** 配置并连接MongoDB **/ var mongoose = require('mongoose'); var uri = 'mongodb://localhost/mongoose-base'; mongoose.connect(uri); /** 建立Schema、建立Model **/ var BookSchema = new mongoose.Schema({ name: String, author: String, publishTime: Date }); mongoose.model('Book', BookSchema);
insert.js
var mongoose = require('mongoose'); require('./model.js'); /** 获取Model,建立Book的实例 Entity **/ var Book = mongoose.model('Book'); var book = new Book({ name: 'MEAN Web Develop', author: 'Green', publishTime: new Date() }); book.author = 'Jim'; // 参数能够从新指定 /** 插入数据 **/ book.save(function(err) { // 执行保存,并查看返回状况 console.log('save status:', err ? 'failed' : 'success'); })
find.js
var mongoose = require('mongoose'); require('./model.js'); var Book = mongoose.model('Book'); /** 查询全部数据 **/ Book.find({}, function(err, docs) { if (err) { console.log('err:', err); return; } console.log(docs) })
findOne.js
var mongoose = require('mongoose'); require('./model.js'); var Book = mongoose.model('Book'); /** 查询一条数据,并修改 **/ Book.findOne({author: 'Jim'}, function(err, doc) { if (err) { console.log('err:', err); return; } doc.author = 'James'; doc.save(); console.log('findOne result:', doc) })
remove.js
var mongoose = require('mongoose'); require('./model.js'); var Book = mongoose.model('Book'); Book.findOne({ author: 'Jim' }, function(err, doc) { if (err) { console.log('findOne err:', err); return; } if (doc) { doc.remove(); } })
var mongoose = require('mongoose'); require('./model.js'); var Book = mongoose.model('Book'); var cond = { $or: [ {author: 'Jim'}, {author: 'James'} ] }; Book.find(cond, function(err, docs){ if(err) { console.log('find by cond err:', err); } console.log('cond:', cond, 'result:', docs); })
这里咱们用express-generator来快速生成express应用(先安装好node、npm、express-generator、mongodb)
$ express mongooseExpress
先看下最终的项目结构图:
新建config文件夹,用来放置数据库配置信息
config/config.js
module.exports = { mongodb: 'mongodb://localhost:27017/mongoose-test' }
config/mongoose.js
var mongoose = require('mongoose'); var config = require('./config.js'); module.exports = function() { var db = mongoose.connect(config.mongodb); require('../models/user.server.model.js'); return db; }
在app.js的路由模块前引用刚才建立的mongoose配置信息(8,9两行)
1 var express = require('express'); 2 var path = require('path'); 3 var favicon = require('serve-favicon'); 4 var logger = require('morgan'); 5 var cookieParser = require('cookie-parser'); 6 var bodyParser = require('body-parser'); 7 8 var mongoose = require('./config/mongoose.js'); 9 var db = mongoose(); 10 11 var index = require('./routes/index'); 12 var users = require('./routes/users');
新建models文件夹
/models/user.server.model.js
var mongoose = require('mongoose'); var UserSchema = new mongoose.Schema({ uid: Number, username: String, createTime: Date, lastLogin: Date }); mongoose.model('User', UserSchema);
咱们直接在users路由模块中加入数据库存取操做的代码
/routes/users.js
1 var express = require('express'); 2 var router = express.Router(); 3 4 var mongoose = require('mongoose'); 5 var User = mongoose.model('User'); 6 7 /* GET users listing. */ 8 router.get('/', function(req, res, next) { 9 res.send('respond with a resource'); 10 }); 11 12 router.get('/test', function(req, res, next) { 13 var user = new User({ 14 uid: 1, 15 username: 'nuanfeng' 16 }) 17 18 user.save(function(err){ 19 if(err) { 20 res.end('Error'); 21 return next(); 22 } 23 24 User.find({}, function(err, docs) { 25 if(err) { 26 res.end('Error'); 27 return next(); 28 } 29 30 res.json(docs); 31 }) 32 }) 33 }) 34 35 module.exports = router;
$ node bin/www
而后在浏览器中访问:http://localhost:3000/users/test,就能往数据库中存入一条记录,并在当前页面返回它的json数据