首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >在sequelize中跨两个表查询

在sequelize中跨两个表查询
EN

Stack Overflow用户
提问于 2021-10-11 09:28:52
回答 1查看 18关注 0票数 1

我对sequelize和mySQL非常陌生,感觉我已经尝试了所有方法,以便将一个搜索词(‘mySQL’)传递给books表(针对标题进行搜索)和authors表(针对first_name或last_name进行搜索)。如果匹配这些值子字符串中的任何一个,它将以JSON对象的形式返回整本书和作者信息。当我将查询的重点放在图书标题上时,它会返回所有内容。当我试图在Author列中传递时,问题就出现了。我尝试了别名,嵌套where子句,所有我能想到的事情,但我在这里或在线上遇到的似乎都不能帮助我弄清楚。

代码语言:javascript
运行
AI代码解释
复制
search: (req, res) => {
    const { query } = req.query;
    Book.findAll({
      include: [Author],
      where: {
        [Op.or]: [
            { title: { [Op.substring]: query } },
        ]},
    })
      .then((Book) => res.json(Book))
      .catch((err) => {
        console.log(err);
        res.status(500).json(err);
      });
  },

以下是工作代码。例如,在where子句中,我想执行{ first_name: { [Op.substring]: query } },,但它没有访问Author表。在include语句中,我尝试了别名,并在where子句中调用它,但这抛出了一个别名错误,说明我已经声明了一个别名( Book.Author.first_name ),但当我尝试将其用作{ 'Author.first_name' { [Op.substring]: query } },时,它返回没有Author。

我可能遗漏了一些简单的东西,所以任何可以帮助我的人,让我知道我在这里做错了什么!

EN

回答 1

Stack Overflow用户

发布于 2021-10-11 12:40:13

解决了,而且超级简单。我缺少用于访问单独的表'$Author.first_name$‘的语法。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69530286

复制
相关文章

相似问题

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