如何在Mongoose中添加一个模式的引用到另一个模式并通过json插入数据?

时间:2015-06-27 10:41:20

标签: javascript node.js mongodb mongoose postman

我正在编写一个node.js应用程序,其中有两个mongoose模式 Wallet User

  • 我想添加 电子钱包作为对用户的引用 ,并从POSTMAN传递适当的json。这就像在OOP中添加一个类的引用,在RDBMS中添加外键概念。

我写了这样的模式:

user.js的

var mongoose = require('mongoose');

var userSchema = new mongoose.Schema({
    userId: {type: String},
    isAdmin: {type: Boolean, default: false},
    password: {type: String},
    name: {type: String},
    wallet: {type: mongoose.Schema.Types.ObjectId, ref: 'Wallet'} //see here
});

module.exports = mongoose.model('User', userSchema);

我上面引用钱包的方式是正确的吗?如果没有,你能告诉我正确的方法吗?

wallet.js

var mongoose = require('mongoose');

var walletSchema = new mongoose.Schema({
    money: {type: Number, default: 0, min: 0},  
});

module.exports = mongoose.model('Wallet', walletSchema);

以下是我的用户路线文件。

userRoute.js

router.route('/user')

.post(function (req, res) {

    var user = new User();

    user.userId = req.body.userId;
    user.password = req.body.password;
    user.name = req.body.name;
    user.isAdmin = req.body.isAdmin;
    user.wallet = req.body.wallet; // see here

    user.save(function(err, user){
        if(err){
            res.json({ message: 'Failure' });
            return false;           
        }
        res.json({ message: 'Success' });
    });     
})

我将钱包分配给用户对象的方式是否正确?如果没有,你能告诉我正确的方法吗?

现在我想发布Postman的原始json。 json会是什么样子?

1 个答案:

答案 0 :(得分:2)

user.wallet = req.body.wallet无效。

User而言user.wallet只是一个ObjectId类型的简单字段,它存储一个24个字符串十六进制字符串的对象:522abc...

这个“参考”实际上是对Mongoose的更高层次的解释。

这就是为什么你不能直接做user.wallet = req.body.wallet。你必须做这样的事情:

var user = new User();
…
// user.wallet = req.body.wallet; // won't work
var wallet = new Wallet(req.body.wallet) // because Wallet too is a Schema just like User
user.wallet = wallet.id;
…