如何使 findOrCreate 的返回值可供路由器使用

Žig*_*pan 3 javascript node.js express sequelize.js

因此,在我的express应用程序中,我有一个单独的文件database.js,其中包含用于插入、删除、更新等的所有模型和函数。我还为每个模型都有一个单独的控制器。

数据库.js

module.exports = {
    createUser: function (username, email, password) {
        return sequelize.sync().then(function () {
            User.findOrCreate({
                where: {
                    username: name,
                    email: email
                },
                defaults: {
                    username: username,
                    password: password,
                    email: email
                }
            }).then(([user, created]) => {
                console.log(user.get({plain:true}));
                console.log(created)
                });
            });
        }
    };
Run Code Online (Sandbox Code Playgroud)

控制器/user.js

const database = require("../database.js");
module.exports = {
    register: function (req, res) {
        database.createUser(req.body.username, req.body.email, req.body.password);
        res.json({...
        })

    }
};
Run Code Online (Sandbox Code Playgroud)

所以基本上我想获取用户对象和布尔值,告诉我它是否已创建到路由器,以便我可以检查用户是否已创建并做出适当的响应。

atl*_*duo 5

您可以在 createUser 中删除then并在调用该函数时解析 Promise:

module.exports = {
    createUser: function (username, email, password) {
        return User.findOrCreate({
                where: {
                    username: name,
                    email: email
                },
                defaults: {
                    username: username,
                    password: password,
                    email: email
                }
            })
    };
Run Code Online (Sandbox Code Playgroud)

然后,该承诺将解析为一个包含用户对象和您要查找的布尔值的数组

const database = require("../database.js");
module.exports = {
    register: function (req, res) {
        database.createUser(req.body.username, req.body.email, req.body.password)
            .then((result) => {
                const [ object, created ] = result;
                res.json({ user_is_created: created })
            })
    }
};
Run Code Online (Sandbox Code Playgroud)

这不是一个完整的解决方案,您可能必须探索边缘情况和错误,但这基本上就是您的做法。