在WHERE 子句中使用ROW_NUMBER() 函數:克服視窗函數限制
視窗函數,例如ROW_NUMBER(),可以實現強大的資料結果集中的轉換。但是,它們的使用受到特定約束,其中之一是將它們排除在 WHERE 子句之外。
如使用者遇到的查詢所示,嘗試在WHERE 子句中使用ROW_NUMBER() 會導致錯誤訊息:「視窗函數只能出現在SELECT 或ORDER BY 子句中。」
要解決此限制,可以採用一種技術來包裝原始函數在公共表表達式(CTE) 中進行查詢,允許在CTE 查詢中包含視窗函數。
以下是實現此解決方案的方法:
修改後的查詢如下所示:
透過將原始查詢包裝在CTE 中,現在可以在WHERE 中使用視窗函數ROW_NUMBER()子句,啟用根據其值過濾結果。
以上是如何在 WHERE 子句中使用 ROW_NUMBER()?的詳細內容。更多資訊請關注PHP中文網其他相關文章!