文章详情页
Mysql update 分组递增 sql咨询
浏览:178日期:2022-06-14 11:40:57
问题描述
表
idlevelsort_num110210320420520630730830930要求得到
idlevelsort_num111212321422523631732833934即页面的展示顺序如下
level1
1
2
level2
1
2
3
level3
1
2
3
4
目前的sql
set @index:=0; update t set sort_num = (@index:=@index+1) where level = 1 order by id;set @index:=0; update t set sort_num = (@index:=@index+1) where level = 2 order by id;set @index:=0; update t set sort_num = (@index:=@index+1) where level = 3 order by id;
不知有没更简洁的sql可以实现上述的需求?
补充在线sql
问题解答
回答1:如果只是为了页面展示,不需要更新表的数据吧。可以试试下面的sql
select level, @sort_num:=if(@prev_level=t1.level, @sort_num+1, 1)from (select * from t order by id) t1, (SELECT @sort_num:=1, @prev_level:=NULL) varorder by id
相关文章:
1. node.js - 对将近2000个网页发起同时20个的并发请求,出去request请求失败2. javascript - SuperSlide.js火狐不兼容怎么回事呢3. docker - 各位电脑上有多少个容器啊?容器一多,自己都搞混了,咋办呢?4. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””5. 图片上传成功但数据库字段是空6. css - 移动端 盒子内加overflow-y:scroll后 字体会变大7. javascript - JQuery如何给新建的img标签添加onload事件,并自动调用。8. java - struts2找不到类文件9. javascript - 解释下这种函数定义10. 百度地图api - Android 百度地图 集成了定位,导航 相互的jar包有冲突?
排行榜

网公网安备