在SQL中创建与条目排名位置对应的列

Posted

技术标签:

【中文标题】在SQL中创建与条目排名位置对应的列【英文标题】:Create column corresponding to entry rank position in SQL 【发布时间】:2015-06-12 21:16:45 【问题描述】:

我正在使用 SQL,并且我有一个如下所示的表:

variable1   123
variable2   39
variable3   993
variable4   2

如果该列已排序,我想添加一个对应于整数等级的列。即:

variable1   123    3
variable2   39     2
variable3   993    4
variable4   2      1

到目前为止,我还无法获得正确的语法 - 我可以按该列排序或排序,但无法生成正确的排名变量。

非常感谢。

【问题讨论】:

为什么要“创建列”? 【参考方案1】:

最好的执行方式是使用变量:

select t.*,
       (@rn := @rn + 1) as rank
from table t cross join
     (select @rn := 0) params
order by intcol;

注意:这在技术上是 row_number(),但对于您的示例数据来说,两者是等效的,因为没有关系。

【讨论】:

【参考方案2】:

听起来您需要在插入之前创建一个触发器,该触发器将更新该列以增加每个变量的排名整数,该变量的值高于您将要插入的值 1。

【讨论】:

以上是关于在SQL中创建与条目排名位置对应的列的主要内容,如果未能解决你的问题,请参考以下文章

如何在 SQL 中使用 C# 创建列

SQL - 从两个表中创建与回显数据的关系

未在 mongoengine 中创建与新 dbname 的连接

如何在 Mosaic 中创建与任何外部数据库的连接?

在子 NSManagedObjectContext 中创建与父实体有关系的实体

如何在代码中创建与 @"H:|-10-[view]" 完全相同的 NSLayoutConstraint 对象?