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

按位置和顺序排列复杂的聚合属性

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

按位置和顺序排列复杂的聚合属性

很遗憾,您不能在

WHERe
HAVINg
语句中使用别名字段,而只能在中使用
ORDERBY
。您必须在
WHERe
子句中重复您的语句,而不要使用别名(就像在Where语句中的SQL Usealias中所说明的那样)。

而且,由于

distance
where
order
属性中使用字段时,Sequelize会自动将其视为
myModel
而不是your的字段
alias
,因此会发生您获得的错误,因此您需要按字面意义编写它,因此不会将其视为表的列选择。

myModel.findAll({    attributes: {        include: [[`(3959 * acos(cos(radians(${user-latitude})) * cos(radians(latitude)) * cos(radians(longitude) - radians(${user-longitude})) + sin(radians(${user-latitude})) * sin(radians(latitude))))`, 'distance']]    },    where: sequelize.where(        sequelize.literal(`(3959 * acos(cos(radians(${user-latitude})) * cos(radians(latitude)) * cos(radians(longitude) - radians(${user-longitude})) + sin(radians(${user-latitude})) * sin(radians(latitude))))`),        '<=',        25    ),    order: 'distance ASC',    limit: 10,    offset: 0});

sequelize
在这种情况下是您的Sequelize实例。



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

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

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