使用 Typescript/Sequelize 传递值数组

下午好,我是一名初级开发人员,一直在尝试使用 Typescript 学习 Sequelize,但遇到了困难。我已经创建了一个简单的查询来根据值进行搜索,但是我无法在不破坏查询的情况下传递一组值。


const findNameTsxData = (limit: number, Name: string): Promise<FinanceStuffs[]> => {

// const { in: opIn, or } = Sequelize.Op;

  return db.FinanceStuffs.findAll({

    where: { Name },

    limit

  });

};

现在,如果我通过邮递员查询作为


Name: "Joe"

Limit: 10,

它返回了 Joe 的 10 个交易,但我希望能够在查询中传递多个名称,例如:


Name: ["Joe", "Alex", "Jacob"]

Limit: 30

我相信答案会以某种方式映射数组,或者使用 Sequelize.Op 但我在尝试时似乎遇到了多个打字稿错误。


如果您能向我解释我做错了什么,作为学习经验将不胜感激。


LEATH
浏览 229回答 1
1回答

牧羊人nacy

您必须使用orsequelize 中的关键字,如文档中提到的例子:const findNameTsxData = (limit: number, Names: string[]): Promise<FinanceStuffs[]> => {const Op = Sequelize.Op;&nbsp; return db.FinanceStuffs.findAll({&nbsp; &nbsp; where: { Name: { [Op.or]: Names } },&nbsp; &nbsp; limit&nbsp; });};in如果您愿意,也可以使用const findNameTsxData = (limit: number, Names: string[]): Promise<FinanceStuffs[]> => {const Op = Sequelize.Op;&nbsp; return db.FinanceStuffs.findAll({&nbsp; &nbsp; where: { Name: { [Op.in]: Names } },&nbsp; &nbsp; limit&nbsp; });};
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript