栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

用NodeJS进行续集无法限制表的连接

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

用NodeJS进行续集无法限制表的连接

实际上,我自己找到了解决方案。我认为这是sequelize框架中的错误。
在node_modules / sequelize / lib / dialect / abstract /
query_generator.js中,有一个“ selectQuery”函数,其内容如下:

subQuery = limit && (options.hasIncludeWhere || options.hasIncludeRequired || options.hasMultiAssociation) && options.subQuery !== false

首先,有一个选项subQuery可以作为false传递,以删除子查询的生成。Sequelize文档对此一言不发。但是此外,如果您在findAll对象中传递subQuery:false,则它将无法正常工作,因为由于某种原因,它对selectQuery函数的定义不够完善。
我尝试了类似的东西:

return models.property.findAll({    where: ["price>=?", 300000],    include: [    {        model:models.entity_area,        where: { area_id:1 }    }    ],    limit:12,    subQuery:false})

仍然有options.subQuery = undefined。

所以我不得不将query_generator.js中的函数更改为类似以下内容:

subQuery = limit && (options.hasIncludeWhere || options.hasIncludeRequired || options.hasMultiAssociation) && options.subQuery !== false && options.doSubQuery===true

So now by default it’s not doing this ugly subquery unless i specify
explicitely doSubQuery:true. And finally i got the proper query without
subquery with limit.



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/435243.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号