MYSQL5.5,分组排序问题

img

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

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

img

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

select * from table where top !=0
union 
select * from table where id in (
  select id from table where top =0 and good!=0 group by userId,id
)