繁体   English   中英

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

[英]How to add reference of one schema to another in Mongoose and inserting data by json?

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

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

我已经写了这样的模式:

用户.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);

我上面提到的钱包的方式对吗? 如果没有,你能告诉我正确的方法吗?

钱包.js

var mongoose = require('mongoose');

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

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

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

用户路由.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 会是什么样子?

user.wallet = req.body.wallet不起作用。

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

这个“参考”其实是对猫鼬的更高层次的诠释。

这就是为什么你不能直接做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;
…

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM