日期:2014-05-16  浏览次数:20797 次

分析函数排序问题求教
我想问分析函数的排序会影响整个SQL语句的排序吗?


如:
select t.*,
  row_number() OVER(PARTITION BY t.aaa order by t.bbb)
  from test1 t
 order by t.aaa

在分析函数内我对t.bbb排序,但我又对整个SQL语句按照t.aaa排序,我想问t.aaa排序受影响吗?测试感觉不受影响,但以前好像听说会影响整体排序,还请高手赐教

------解决方案--------------------
结果相当于
select t.*,
from test1 t
 order by t.aaa,t.bbb
不受影响

------解决方案--------------------
不受影响的
------解决方案--------------------
肯定不受影响啊 一个是局部 一个是整体排序 相当于是子查询 只正对内部的排序
------解决方案--------------------
是有影响的,你比较一下二者的执行计划,加排序的成本会高一些。