___rain 2018-02-10 09:55 采纳率: 40%
浏览 2986
已采纳

mysql 分组排序更新字段的排序号,大神来分析一下

图片说明
目标是按照每个txtShopCode来更新字段sort类似自增,但是有条件。比如txtShopCode
为1我更新sort字段他有三条记录,我从1到3更新完成,txtShopCode为2的时候更新sort
字段有5条记录,更新的时候要重新从1开始,不懂的再给你讲解一下。望大神指导

  • 写回答

5条回答 默认 最新

  • 张大教主 2018-02-11 03:23
    关注
    我理解你的意思是相同txtShopCode值的记录要按照从1递增更新sort字段值?
    如果这样的话,也简单,但是为了方便更新执行,需要增加一个辅助更新字段,名称:num,更新后可删除该字段
        假定你的表名为 tname
        alter table tname add num INT NOT NULL AUTO_INCREMENT;----增加递增字段
        update tname set sort=1 where 1=1;----先将所有sort字段赋初始值1;
        update tname m  inner join 
        (select a.txtGuid guid,
            (select count(*) from tname where num<=a.num and txtShopCode=a.txtShopCode) sortValue from tname a) n
        on m.txtGuid=n.guid 
        set m.sort=n.sortValue;
        alert table tname drop column num;----删除新增字段num
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了