首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Objection.js -根据"where“条件插入数据

Objection.js -根据"where“条件插入数据
EN

Stack Overflow用户
提问于 2020-10-02 23:11:30
回答 1查看 251关注 0票数 0

我想根据"where“条件将数据插入到我的数据库中,但我无法成功。

Objection.js:

代码语言:javascript
复制
const User = require('../../database/models/user');

router.route('/register')
.get((req,res,next)=>{
    res.render('user/register')
})
.post((req,res,next)=>{
    const {email, password} = req.body;
    const user = User.query().where('email', '=', email);
    
    if(user){
       console.log('user exists');
       // do something
    }
    if(!user){
       console.log('user doesnt exist');
       // do something
    }
})

在任何情况下,它都会输出"user exists“。我想这是因为"user“返回了一个承诺。

我还试着这样做:

代码语言:javascript
复制
const User = require('../../database/models/user');

router.route('/register')
.get((req,res,next)=>{
    res.render('user/register')
})
.post((req,res,next)=>{
    const {email, password} = req.body;
    User.query().where('email', '=', email).then(row => {
        if(row.length == 1){
            console.log('user exists');
        }
        if(row.length == 0){
            User.query().insert({
                email : email,
                password : password
            })
        }
    });
})

但是它不会将数据插入数据库。我不知道如何根据条件将数据插入到数据库中。你知道我怎么才能修好它吗?谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-05 14:47:24

insert查询中缺少.then或等待

这应该是可行的:

代码语言:javascript
复制
const User = require('../../database/models/user');

router.route('/register')
.get((req,res,next)=>{
    res.render('user/register')
})
.post((req,res,next)=>{
    const {email, password} = req.body;
    User.query().where('email', '=', email).then(row => {
        if(row.length == 1){
            console.log('user exists');
        }
        if(row.length == 0){
            User.query().insert({
                email : email,
                password : password
            }).then(result => {
              res.status(204).send();
            })
        }
    });
})
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64174003

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档