免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1569 | 回复: 4
打印 上一主题 下一主题

[排序 2个字段]排序问题, 请指教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-12-11 21:45 |只看该作者 |倒序浏览
两个字段: name和score
及格的(score>=60)和不及格的都按name顺序排序
及格和不及格哪个在前都无所谓, 比如:
a, 65
t, 90
w, 60
b, 45
x, 57
z, 35
这样的查询怎么写? 谢谢!

[ 本帖最后由 yejr 于 2005-12-12 13:15 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2005-12-12 09:00 |只看该作者
设置表的别名,然后用union连接及格和不及格两部分,这样是不是就可以了?

论坛徽章:
0
3 [报告]
发表于 2005-12-12 09:12 |只看该作者

补充一下

这样写不知行不行?我没试过啊。你试试吧
(select * from tablename where score> 60 order by name) union (select * from tablename where score< 60 order by name)

论坛徽章:
0
4 [报告]
发表于 2005-12-12 09:13 |只看该作者

更正一下下

select * from tablename where score> 60 order by name  union all  select * from tablename where score< 60 order by name

论坛徽章:
0
5 [报告]
发表于 2005-12-12 12:46 |只看该作者
原帖由 snowseya 于 2005-12-12 09:13 发表
select * from tablename where score> 60 order by name  union all  select * from tablename where score< 60 order by name

好像order by 以后再union出问题了(bug?)
看看
(select * from test where score>=60 order by name) union (select * from test where score<60 order by name)
的结果
a=>234
y=>80
s=>66
z=>34
r=>45
h=>12
k=>6
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP