gpt4 book ai didi

javascript - 如何将动态查询参数对象转换为 Sequelize 运算符(Javascript 符号)

转载 作者:行者123 更新时间:2023-12-03 22:36:56 24 4
gpt4 key购买 nike

我有一个动态 filter 方法,它传递我需要用来过滤我的 Sequelize 查询的属性。例如,我可能想按特定价格范围和制造日期过滤 Cars 列表。导致客户端查询如下所示:

const response = await this.get('cars', {
price: {
gt: 80000
lt: 1200000
},
year: 2019
})

查询参数将被序列化,发送到我的服务器,然后解码回对象形式。在这个查询中,我需要使用 Sequelize 的 [Op.gt][Op.lt] 符号,因为我需要按价格范围进行过滤。我怎样才能动态地将我的对象转换成这样:
const Op = require('sequelize').Op;

const whereParams = {
price: {
[Op.gt]: 80000,
[Op.lt]: 120000
},
year: 2019
}

这样我就可以在我的 where 属性中使用它们:
router.get('cars', (req, res) => {
Car.findAll({
where: whereParams
}).then((cars) => {
res.status(200).send(cars);
})
})

我不能简单地对 Sequelize 对象进行硬编码,因为这个过滤器参数是动态的,谢谢!

最佳答案

至少对于您的简单示例,json-transormer-node 可以完成工作。

首先,确保 Sequelize 对象具有运算符别名:

 ... 
dialect: 'mysql',
operatorsAliases: { $lt: Op.lt, $gt: Op.gt},
define: {
...

然后,设置转换:
const nodeJsonTransformer = require('json-transformer-node');

var carFilter = {
price: {
gt: 80000
lt: 1200000
}
}

var transformation = {
mapping : {
item : {
price : {
$gt : 'price.gt',
$lt : 'price.lt'
}
}
}
};

var whereValues = nodeJsonTransformer.transform(carFilter, transformation);
Car.findAll( {where: whereValues})

生成的查询应包括 WHERE price > 8000 AND price < 12000 。警告:如果你有一个复杂的过滤器,这可能会很麻烦......

关于javascript - 如何将动态查询参数对象转换为 Sequelize 运算符(Javascript 符号),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58156930/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com