文章详情页
Mysql update 分组递增 sql咨询
浏览:223日期: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. javascript - 手机网页如何,插入地图 ;并设置多个标注点 ,还可路线查询2. 怎么学好php3. javascript - 项目用IE浏览器打开修改前端内容,后台数据修改了,但是前端页面内容不变,用谷歌浏览器测试前端页面可以刷新,求大神解决。4. thinkphp6中怎么把类放到容器中?5. vue.js - 为什么我的vue项目上传到github不能预览?6. python 如何打印bytes以16进制输出7. 如何将行内块元素的内容垂直水平两个方向居中?8. 如何更新/删除指定的两条或多条数据9. mysql - 把一个表中的数据count更新到另一个表里?10. javascript - Ajax加载Json时,移动端页面向左上角缩小一截儿,加载完成后才正常显示,这该如何解决?
排行榜

网公网安备