文章详情页
Mysql update 分组递增 sql咨询
浏览:53日期: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. android - Listview模仿朋友圈点赞的TextView没有刷新?2. mysql - 索引过滤性不好是由什么原因引起的,应该怎么解决3. javascript - 修改表单多选项时和后台同事配合的问题。4. 网页爬虫 - Python:爬虫的中文编码问题?5. dockerfile - [docker build image失败- npm install]6. angular.js - angularjs 怎么封装 upload 上传7. javascript - vue生成一维码?求助!!!!!急8. docker内创建jenkins访问另一个容器下的服务器问题9. mysql - 我的myeclipse一直连显示数据库连接失败,不知道为什么10. javascript - H5页面怎么查看console信息?
排行榜
