Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/37.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript Sequelize包含模型但不包含表名_Javascript_Node.js_Express_Sequelize.js_Sequelize Cli - Fatal编程技术网

Javascript Sequelize包含模型但不包含表名

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(

我是Sequelize的新手

我对“嵌套的即时加载”有问题

我有两张1对多关系的桌子

  • 注释表

  • 用户表

  • 我使用此代码进行查询

    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);
    });