PostgreSQL 表按日期/時間排序,優先處理 NULL 值
資料庫管理員經常需要以特定順序排序數據,PostgreSQL 提供多種選項來自訂排序行為。常見場景是按日期/時間欄位排序,同時根據所需順序處理 NULL 值。
問題:NULL 值優先排序
假設需要按 'last_updated' 日期/時間欄位升序排序表,優先處理 NULL 值的記錄。挑戰在於 PostgreSQL 的預設升序 (ASC) 將 NULL 值放在結果的最後。
解決方案:使用 NULLS FIRST 修飾符
PostgreSQL 為 ORDER BY 表達式提供了 'NULLS FIRST | LAST' 修飾符。在 ORDER BY 子句中向 'last_updated' 欄位新增 'NULLS FIRST' 修飾符可確保 NULL 值的記錄出現在非 NULL 值之前:
<code class="language-sql">... ORDER BY last_updated NULLS FIRST</code>
NULLS LAST 和索引支援
對於降序排序 (DESC),典型用例是 'NULLS LAST',它反轉預設的升序,將 NULL 值放在開頭。若要將 NULL 值排序到最後,請使用:
<code class="language-sql">... ORDER BY last_updated DESC NULLS LAST</code>
為了最佳化帶有索引的查詢,請確保索引與排序順序相符:
<code class="language-sql">CREATE INDEX foo_idx ON tbl (last_updated DESC NULLS LAST);</code>
效能注意事項
NULL 值的位置會影響查詢效能。對於某些查詢計劃,PostgreSQL 會嘗試將 NULL 值附加到開頭 ('NULLS FIRST') 或結尾 ('NULLS LAST')。以下連結提供了有關效能影響的見解:
以上是如何按日期/時間對 PostgreSQL 表排序,優先考慮 NULL 值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!