首页 > 解决方案 > 如何在模型上运行 RANK() 函数

问题描述

如何运行rank 函数以在给定的 sequelize 模型上生成属性?

例如,给定模型:

Players.init(
  {
    id: {
      type: DataTypes.INTEGER,
      primaryKey: true,
      allowNull: false
    },
    rating: type: DataTypes.FLOAT
  },
  { sequelize }
)

我想rank在运行时获得一个属性Players.getAll({ rank: rating })。这将生成类似于以下内容的 SQL:

SELECT id, rating, RANK() OVER (ORDER BY rating DESC) as rank FROM players

我将如何使用续集来做到这一点?

标签: sql-serversequelize.js

解决方案


您可以使用 Sequelize Literal Function 如下 -

attributes: [
          'id', 'rating',
          [Sequelize.literal('(RANK() OVER (ORDER BY rating DESC))'), 'rank']
    ]

创建新属性。


推荐阅读