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

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条)

报告相同问题?

悬赏问题

  • ¥50 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?