文章详情页
Mysql update 分组递增 sql咨询
浏览:137日期: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. html - vue项目中用到了elementUI问题2. redis sentinel怎么跑守护进程以及日志记录位置的?3. javascript - jquery事件绑定中的this指向问题4. javascript - sublime什么插件可以在我自动保存代码之后,对es6代码自动检查并格式化。5. docker start -a dockername 老是卡住,什么情况?6. mysql - msql什么叫并发7. angular.js使用$resource服务把数据存入mongodb的问题。8. node.js - session怎么存到cookie,然后服务器重启后还能获取。数据库不用mongodb或redis,数据库是mysql9. python - pyspider的分布式运行成功,2台slave跑,但是时间并没有缩短问题?10. python - Django中如何使用异步
排行榜

网公网安备