日期:2014-05-18  浏览次数:20395 次

SQL多字段比较排序问题
表名:aaa
aid a_addtime content
1 2012-01-01 xxx
2 2012-01-02 xxx
3 2012-01-03 xxx
4 2012-01-30 xxx
表名:bbb
bid a_aid b_addtime
1 2 2012-01-08
2 4 2012-02-01
表名:ccc
cid aa_aid c_addtime
1 3 2012-01-05


SQL code

SELECT * FROM (aaa a LEFT JOIN bbb b ON a.aid=b.a_aid) LEFT JOIN ccc c ON a.aid=c.aa_aid
WHERE content='xxx'
ORDER BY a.a_addtime DESC,b.b_addtime DESC,c.c_addtime DESC



这样得到的结果是





期望得到的结果






总而言之就是 比较a_addtime b_addtime c_addtime的大小进行排序


------解决方案--------------------
用你的数据和测试语句 我怎么得到的是下面的结果


SQL code

aid         a_addtime               content bid         a_aid       b_addtime               cid         aa_aid      c_addtime
----------- ----------------------- ------- ----------- ----------- ----------------------- ----------- ----------- -----------------------
4           2012-01-30 00:00:00.000 xxx     2           4           2012-02-01 00:00:00.000 NULL        NULL        NULL
3           2012-01-03 00:00:00.000 xxx     NULL        NULL        NULL                    1           3           2012-01-05 00:00:00.000
2           2012-01-02 00:00:00.000 xxx     1           2           2012-01-08 00:00:00.000 NULL        NULL        NULL
1           2012-01-01 00:00:00.000 xxx     NULL        NULL        NULL                    NULL        NULL        NULL

(4 行受影响)