mysql - 根据另一列的顺序制作一列
问题描述
我有一张名为汽车的桌子,上面有一堆列。
我想创建一个名为“Make_ID”的列,它将根据字母顺序或“Make”列递增。
我的目标是给每个 Make String 一个唯一的整数,例如无论我有一个“Ford”品牌的记录,Make_ID 将始终是,例如,数字 3 或者如果我有一个“Mazda”品牌Make_ID 编号将是 15 永远具有马自达品牌的记录。
有办法吗?
解决方案
如果您有数据并且只想在结果集中使用它,请使用dense_rank()
:
select c.*, dense_rank() over (order by make) as make_id
from cars c
推荐阅读
- arrays - 过滤调用重复颤动
- python - 使用 numpy 的线性和非线性系统的雅可比行列式
- json - 我的 Conditional0 JSON 语句未按预期工作
- mongodb - Spring Data Mongo Db 使用 @DBRef 从返回 null 的某个集合中获取值
- json - 如何通过在 Flutter 中以 JSON_Serializable 方式遍历 JSON 数组来填充 GridView?
- matlab - for循环中的索引问题?位置 2 中的索引超出数组边界(不得超过 27630)。MATLAB
- google-cloud-storage - 通过 Google 实例的公共 url 从存储桶下载对象是否收费?
- python - 在 Matplotlib 中绘制带有图例的数据框线图
- python - 总是与 NumPy 的深度维度混淆
- javascript - 如何隐藏div中的第二个元素?