2017-12-28 14 views
0

私は後継者が新しく、タスクの関係がnullのユーザーテーブル内のすべてのエントリを読み込もうとしています。しかしそれは働かない。ここで私が試したものです:私は3人のユーザーを持っており、それらのユーザーの2は、各タスクを持っている場合続行の際にrelationがnullである項目をロードする

const express = require('express'); 
const app = express(); 

const Sequelize = require('sequelize'); 
const sequelize = new Sequelize('sequelize', 'mazinoukah', 'solomon1', { 
    host: 'localhost', 
    dialect: 'postgres', 

    pool: { 
    max: 5, 
    min: 0, 
    acquire: 30000, 
    idle: 10000, 
    }, 
}); 

const Task = sequelize.define('Task', { 
    name: Sequelize.STRING, 
    completed: Sequelize.BOOLEAN, 
    UserId: { 
    type: Sequelize.INTEGER, 
    references: { 
     model: 'Users', // Can be both a string representing the table name, or a reference to the model 
     key: 'id', 
    }, 
    }, 
}); 

const User = sequelize.define('User', { 
    firstName: Sequelize.STRING, 
    lastName: Sequelize.STRING, 
    email: Sequelize.STRING, 
    TaskId: { 
    type: Sequelize.INTEGER, 
    references: { 
     model: 'Tasks', // Can be both a string representing the table name, or a reference to the model 
     key: 'id', 
    }, 
    }, 
}); 

User.hasOne(Task); 
Task.belongsTo(User); 

app.get('/users', (req, res) => { 
    User.findAll({ 
    where: { 
     Task: { 
     [Sequelize.Op.eq]: null, 
     }, 
    }, 
    include: [ 
     { 
     model: Task, 
     }, 
    ], 
    }).then(function(todo) { 
    res.json(todo); 
    }); 
}); 

    app.listen(2000,() => { 
     console.log('server started'); 
    }); 

、私は仕事せずに、単に最後のユーザーをロードします。続けることが可能ですか?

答えて

1

は非常にデバッグした後、私は句

where: { 
    '$Task$': null, 
}, 

私は仕事せずにユーザーのみをロードすることができたところにこれを追加することで解決

app.get('/users', (req, res) => { 
User.findAll({ 
    where: { 
     '$Task$': null, 
    }, 
    include: [ 
     { 
     model: Task, 
     required: false, 
     }, 
    ], 
    }).then(function(todo) { 
    res.json(todo); 
    }); 
}); 

を見つけ

関連する問題