MYSQL5.5,分组排序问题

img

源数据如图
1、先把top不为0的记录置顶后随机排序(底色为浅红色的记录)
2、然后把good不为0的记录按照userid分组,分组后的记录按组随机排序(底色为浅绿色的记录)
特殊记录处理:top不为0同时good不为0的记录,需要同时参与以上1、2条的排序(底色为浅蓝色的记录)

想要达到下图所示的排序效果

img

如果无法用mysql语句实现,也可以配合PHP代码加以实现

上下2个查询结果,各自排序,然后 union all 不就行了