热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MySQL在同一列上排序两次

如何解决《MySQL在同一列上排序两次》经验,为你挑选了1个好方法。

我的数据库就像

id|service_id
1 | 8
2 | 3
3 | 4
4 | 1
5 | 3
6 | 2
7 | 1

我想将它排序为像行一样service_id但是随机的.喜欢

id|service_id
1 | 8
4 | 1
7 | 1
2 | 3
5 | 3
6 | 2
3 | 4

意味着首先排序所有行service_id然后通过随机排序service_id.我也试过试过SELECT * from sample_table order by service_id DESC,ASC但它只通过DESC或排序ASC.我也尝试order by rand(service_id)了,但它也显示了一些固定的排序.



1> juergen d..:
select t.*
from your_table t
join 
(
  select service_id, rand() as r
  from your_table 
  group by service_id
) tmp on t.service_id = tmp.service_id
order by tmp.r;

SQLFiddle演示

基本上这可以随意替代service_id和命令


推荐阅读
author-avatar
张怡如秋岳
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有