node.js下mongoose简单操作实例
发布于 11 年前 作者 fourlee 97087 次浏览 最后一次编辑是 8 年前

Mongoose API : http://mongoosejs.com/docs/api.html

// mongoose 链接
var mongoose = require('mongoose');
var db       = mongoose.createConnection('mongodb://127.0.0.1:27017/NodeJS'); 
// 链接错误
db.on('error', function(error) {
    console.log(error);
});
// Schema 结构
var mongooseSchema = new mongoose.Schema({
    username : {type : String, default : '匿名用户'},
    title    : {type : String},
    content  : {type : String},
    time     : {type : Date, default: Date.now},
    age      : {type : Number}
});
// 添加 mongoose 实例方法
mongooseSchema.methods.findbyusername = function(username, callback) {
    return this.model('mongoose').find({username: username}, callback);
}
// 添加 mongoose 静态方法,静态方法在Model层就能使用
mongooseSchema.statics.findbytitle = function(title, callback) {
    return this.model('mongoose').find({title: title}, callback);
}
// model
var mongooseModel = db.model('mongoose', mongooseSchema);
// 增加记录 基于 entity 操作
var doc = {username : 'emtity_demo_username', title : 'emtity_demo_title', content : 'emtity_demo_content'};
var mongooseEntity = new mongooseModel(doc);
mongooseEntity.save(function(error) {
    if(error) {
        console.log(error);
    } else {
        console.log('saved OK!');
    }
    // 关闭数据库链接
    db.close();
});
// 增加记录 基于model操作
var doc = {username : 'model_demo_username', title : 'model_demo_title', content : 'model_demo_content'};
mongooseModel.create(doc, function(error){
    if(error) {
        console.log(error);
    } else {
        console.log('save ok');
    }
    // 关闭数据库链接
    db.close();
});
// 修改记录
mongooseModel.update(conditions, update, options, callback);
var conditions = {username : 'model_demo_username'};
var update     = {$set : {age : 27, title : 'model_demo_title_update'}};
var options    = {upsert : true};
mongooseModel.update(conditions, update, options, function(error){
    if(error) {
        console.log(error);
    } else {
        console.log('update ok!');
    }
    //关闭数据库链接
    db.close();
});
// 查询
// 基于实例方法的查询
var mongooseEntity = new mongooseModel({});
mongooseEntity.findbyusername('model_demo_username', function(error, result){
    if(error) {
        console.log(error);
    } else {
        console.log(result);
    }
    //关闭数据库链接
    db.close();
});
// 基于静态方法的查询
mongooseModel.findbytitle('emtity_demo_title', function(error, result){
    if(error) {
        console.log(error);
    } else {
        console.log(result);
    }
    //关闭数据库链接
    db.close();
});
// mongoose find
var criteria = {title : 'emtity_demo_title'}; // 查询条件
var fields   = {title : 1, content : 1, time : 1}; // 待返回的字段
var options  = {};
mongooseModel.find(criteria, fields, options, function(error, result){
    if(error) {
        console.log(error);
    } else {
        console.log(result);
    }
    //关闭数据库链接
    db.close();
});
// 删除记录
var conditions = {username: 'emtity_demo_username'};
mongooseModel.remove(conditions, function(error){
    if(error) {
        console.log(error);
    } else {
        console.log('delete ok!');
    }

    //关闭数据库链接
    db.close();
});
29 回复

非常感谢 ,正在学习很需要这个

支持一下 :)

有时候JS 为什么要加$…原谅我 问这么小白的问题

感谢楼主,提供这样精悍的代码,快速了解诶代码机制

@1340641314 标记。收藏。

楼主麻烦问一下,基于model操作和静态操作对程序有什么影响吗?对于操作是肯定都能完成的,其他方面呢?

@1340641314 记下来了,也有保存以后再看的意思

同步代码怎么写?

@yakczh promise、async相关的库挺多的,到是事务不好处理。

@liygheart 分页的逻辑要自己实现吧,这里他只是提供简单的CRUD操作,分页有limit,setLimit

基于实例方法的查询和基于静态方法的查询有问题吧 Entity 必须实例之后才可以查询吧 statics 不需要model之后查询吧

schema.methods.findByUserName = function(callback) {
    return this.model('users').find({user: this.user}, callback)
}

schema.statics.findByUserName = function(username, callback) {
    return this.find({user: username}, callback)
}

var mongooseModel = db.model('users', schema);

// entity find
var mongooseEntity = new mongooseModel({user: 'user_100'});
mongooseEntity.findByUserName(function(err, docs) {
    if (err) return console.log(err);
    console.log(docs);
    db.close();
})

// statics find
mongooseModel.findByUserName('user_100', function(err, docs) {
    if (err) return console.log(err);
    console.log(docs);
    db.close()
})

2018年占个坑,感谢楼主

回到顶部