Javascript Sequelize包含模型但不包含表名
我是Sequelize的新手 我对“嵌套的即时加载”有问题 我有两张1对多关系的桌子Javascript Sequelize包含模型但不包含表名,javascript,node.js,express,sequelize.js,sequelize-cli,Javascript,Node.js,Express,Sequelize.js,Sequelize Cli,我是Sequelize的新手 我对“嵌套的即时加载”有问题 我有两张1对多关系的桌子 注释表 用户表 我使用此代码进行查询 Comment.findAll({ include: [User] }) 我得到 但我期待这样的结果 { id: 1, comment: "test", user_id: 3, user_name: "someone" } 我读了几篇stackoverflow文章,它有一个解决方案,但适用于3.3版 Comment.findAll(
Comment.findAll({
include: [User]
})
我得到
但我期待这样的结果
{
id: 1,
comment: "test",
user_id: 3,
user_name: "someone"
}
我读了几篇stackoverflow文章,它有一个解决方案,但适用于3.3版
Comment.findAll({
attributes: ['id', 'name', ['user.id','user_id'], ['user.name','user_name']]
include: [{ model: User, attributes:[], nested: false, required: true }]
})
但这对我不起作用
现在我使用sequelize 5.5.1如何实现它
有人能帮我吗
我的女朋友伤了我的心。你是唯一可以通过回答这个问题来治愈我心灵的人。你可以使用此代码获得所需的输出: 由于Sequelize是基于承诺的,因此建议使用then和catch
Comment.findAll({
include: [User]
}).then(result=>
{
let obj=
{
id: result.item,
comment: result.comment,
user_id: result.user.id,
user_name: result.user.name
};
console.log(JSON.stringify(obj));
}).catch(err=>
{
console.log(err);
});
你找到解决这个问题的方法了吗?@Kiax没有,但我使用的方法是改变我的前端。
Comment.findAll({
attributes: ['id', 'name', [Sequelize.col('user.id'),'user_id'], [Sequelize.col('user.name'),'user_name']]
include: [{ model: User, attributes:[], nested: false, required: true }]
})
Comment.findAll({
include: [User]
}).then(result=>
{
let obj=
{
id: result.item,
comment: result.comment,
user_id: result.user.id,
user_name: result.user.name
};
console.log(JSON.stringify(obj));
}).catch(err=>
{
console.log(err);
});