文章详情页
Mysql update 分组递增 sql咨询
浏览:211日期: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. mysql - 一个sql的问题2. android glide asbitmap 在baseadpter中的问题3. javascript - 百度echarts图表如何修改4. python - flask post提交timestamp不能作为参数,这是为什么?5. node.js - express框架,设置浏览器从缓存中读取静态文件,只有js从缓存中读取了,css还有一些图片为何没有从缓存中读取?6. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!7. 如何解决Centos下Docker服务启动无响应,且输入docker命令无响应?8. spring-mvc - spring-session-redis HttpSessionListener失效9. javascript - 如何获取未来元素的父元素在页面中所有相同元素中是第几个?10. linux - redis连接池应用在一万并发下时连接数只有2?
排行榜

网公网安备