Sequelize之指定'where'查询结果与预期不一致(已解决但原因待究)

栏目: 数据库 · 发布时间: 6年前

内容简介:最近在敲Sequelize的时候遇到一个奇怪的问题。我的代码类似酱紫:此时我的

最近在敲Sequelize的时候遇到一个奇怪的问题。

我的代码类似酱紫:

const tagFilter = tag ? { name: tag } : {}
const categoryFilter = category ? { name: category } : {}
await Article.findAndCountAll({
    include: [
        { model: Tag, attributes: ['name'], where: tagFilter },
        { model: Category, attributes: ['name'], where: categoryFilter }
    ],
    offset: 0,
    limit: 10,
    order: [['createdAt', 'DESC']],
    row: true,
    distinct: true
});

此时我的 Article 模型对应的数据库 Article 表有 12 条数据:

Sequelize之指定'where'查询结果与预期不一致(已解决但原因待究)

Tag 模型和 Category 模型没有查询条件的时候:

const tagFilter = {}
const categoryFilter = {}

预期结果应该是能得到 12 条数据,然而我得到的却是:

Sequelize之指定'where'查询结果与预期不一致(已解决但原因待究)

纳尼?怎么只有 10 条数据???我的 柠檬7柠檬8 呢!!!

后来发现,愚蠢如我忘记在数据库的 Tag 表和 Category 表加上 柠檬7柠檬8 的数据了。待我为这两篇文章都指定好tag和category之后,查出来的结果终于正确了。

然而,为什么?

先mark下来,以后搞懂了再回来填坑。欢迎路过的大侠指点一二~


以上所述就是小编给大家介绍的《Sequelize之指定'where'查询结果与预期不一致(已解决但原因待究)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

上瘾

上瘾

[美] 尼尔·埃亚尔、[美] 瑞安·胡佛 / 钟莉婷、杨晓红 / 中信出版集团 / 2017-5 / 49.00元

——为什么我们会习惯性地点开某个App? ——这种使用习惯到底是如何养成的? ——为什么有些产品能让我们戒不掉,而其他的产品却不行? ——是否有什么秘诀能让用户对你的产品形成使用习惯,欲罢不能? 《上瘾》揭示了很多让用户形成使用习惯,甚至“上瘾”的互联网产品服务背后的基 本设计原理,告诉你怎样打造一款让用户欲罢不能的产品。作者根据自己多年的研究、咨询及实际经验,提出了新颖而......一起来看看 《上瘾》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

SHA 加密
SHA 加密

SHA 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具