row_number()随机性
时间: 2023-08-30 15:08:51 浏览: 183
如果外层查询是通过限制WHERE RN=1来取值,那取值结果就会存在随机性。当使用ROW_NUMBER()函数时,如果没有指定明确的排序规则或分组字段,结果可能会随机排序。所以,如果ROW_NUMBER()函数的分组字段不是最细粒度,就会导致结果的随机性。
在提供的例子中,使用了ROW_NUMBER()函数对ID进行分组,并按照DT字段降序排序。所以,当WHERE RN = 1时,结果取的是每个ID组中DT最大的一行,这个结果是按照DT降序排序的。
总之,如果要避免ROW_NUMBER()函数的随机性,需要确保在排序和分组规则中使用最细粒度的字段。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [row_number()函数随机排序](https://blog.csdn.net/u010918936/article/details/125840751)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]