」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 在 Laravel 中對底部為空值和非空值的行進行降序排序

在 Laravel 中對底部為空值和非空值的行進行降序排序

發佈於2024-11-06
瀏覽:365

Sorting Rows with Empty Values at the Bottom and Non-Empty Values in Descending Order in Laravel

使用資料庫時,經常會遇到某些欄位可能為空或 NULL 的情況。經常出現的一個挑戰是如何對記錄進行排序,以便具有空字段的行出現在結果集的底部,而具有非空值的行以有意義的方式排序(例如,降序)。在這篇文章中,我將透過一個實際範例向您展示如何在 Laravel 中實現這一目標。

設想

假設您有一個活動的參與者表,每個參與者可能有也可能沒有 attend_at 時間戳,它記錄了參與者參加活動的時間。您想要列出所有參與者,並按以下方式對它們進行排序:

  • 已出席的參與者(即 attend_at 不為空)首先出現,按最近出席的順序排序。
  • 未參加的參與者(即 attend_at 為空或 NULL)出現在最後。

問題

預設情況下,Laravel 的latest() 方法按給定列以降序對記錄進行排序。但是,它不處理某些記錄具有 NULL 或空值的情況。如果你只是使用:

return $this
    ->participants()
    ->with('user')
    ->latest('attended_at')
    ->get();

它將使用時間戳對參與者進行排序,但不會將 NULL 值移到底部。

解決方案:使用 orderByRaw

我們可以使用 orderByRaw() 方法實作所需的排序。這允許我們使用原始 SQL 表達式編寫自訂排序邏輯。在這種情況下,我們將根據 attend_at 是否為 NULL 進行排序,然後根據 attend_at 對非 NULL 值進行降序排序。

以下是在 Laravel 中編寫此查詢的方法:

return $this
    ->participants()
    ->with('user')
    ->orderByRaw('attended_at IS NULL, attended_at DESC')
    ->get()
    ->map(function (ActivityParticipant $participant) {
        return [
            'metric_number' => data_get($participant, 'user.student_id'),
            'name' => data_get($participant, 'user.name'),
            'status' => data_get($participant, 'status'),
            'attended_at' => data_get($participant, 'attended_at', '-'),
        ];
    })->toArray();

分解查詢

  • orderByRaw('attending_at IS NULL, attend_at DESC'):
    • attend_at IS NULL:對於 attend_at 為 NULL 的行,這將傳回 true(或 1),否則傳回 false(或 0)。這有效地將 NULL 值放在底部。
    • attend_at DESC:處理 NULL 值後,按降序對具有非空 attend_at 值的剩餘行進行排序,這表示最近的出席將首先顯示。

最終輸出

然後使用map()函數將輸出格式化為所需的結構,包括student_id、name和status等字段,並將attent_at時間戳轉換為人類可讀的格式或“-”(如果是)空的。

這種方法的好處

  • 效能:這種方法利用了 SQL 的排序功能,使其對於大型資料集非常有效率。
  • 可讀性:使用 orderByRaw() 和原始 SQL 表達式可以使程式碼簡潔且易於理解。
  • 靈活性:您可以輕鬆擴展此邏輯以按其他欄位排序或包含更複雜的條件。

結論

在 Laravel 中處理 NULL 或空值排序是處理可能並不總是完整的資料時的常見任務。透過將 orderByRaw() 方法與 SQL 表達式(如 attend_at IS NULL、attend_at DESC)結合使用,您可以輕鬆確保具有 NULL 值的行出現在底部,同時仍以有意義的方式對其餘資料進行排序。

此方法在處理考勤的情況下特別有用,如本範例所示,但它也可以應用於某些資料欄位可能遺失的許多其他情況。透過這種方法,您可以在應用程式中為使用者提供更清晰、更直觀的記錄顯示。

編碼愉快!

版本聲明 本文轉載於:https://dev.to/nasrulhazim/sorting-rows-with-empty-values-at-the-bottom-and-non-empty-values-in-descending-order-in-laravel-2ao9? 1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 專案透過其介面引用對象
    專案透過其介面引用對象
    介面作為引用型別的偏好: 如果存在合適的接口,您應該透過它引用對象而不是具體的類別。 這適用於參數、傳回值、變數和欄位。 使用介面的彈性: 使用介面允許您更改實作而不影響程式碼。 範例:從 LinkedHashSet 變更為 HashSet 或 TreeSet,只需更改建構子即可。 何時不使...
    程式設計 發佈於2024-11-06
  • 如何防止遊戲網站頁面載入時重複插入?
    如何防止遊戲網站頁面載入時重複插入?
    調試頁面載入時的重複插入在遊戲網頁上,觀察到使用者活動查詢在頁面刷新時將重複記錄插入資料庫。 $insert_user_activity = mysql_query("INSERT INTO game_activity (user_id,user_full_name,game_id,gam...
    程式設計 發佈於2024-11-06
  • Python 最佳實務:編寫乾淨、有效率且可維護的程式碼
    Python 最佳實務:編寫乾淨、有效率且可維護的程式碼
    Python 因其简单性、可读性和多功能性而成为最流行的编程语言之一。 无论您是经验丰富的开发人员还是初学者,遵循 Python 最佳实践对于编写干净、高效和可维护的代码至关重要。 在这篇博文中,我们将探讨编写 Python 代码时要牢记的一些关键最佳实践。 1 - 遵守 PEP...
    程式設計 發佈於2024-11-06
  • std::lock_guard 與 std::scoped_lock:何時使用哪個鎖?
    std::lock_guard 與 std::scoped_lock:何時使用哪個鎖?
    std::lock_guard 與std::scoped_lock:為任務選擇正確的鎖隨著C 17 的引入,std :: scoped_lock 類別與現有的std::lock_guard 一起出現,引發了關於它們之間的差異以及何時使用它們的問題。 雖然 std::scoped_lock 與 std...
    程式設計 發佈於2024-11-06
  • WebRTC簡介
    WebRTC簡介
    安裝和代碼指南 WebRTC(網路即時通訊)是一種開源技術,可透過網頁瀏覽器和行動應用程式中的簡單 API 進行即時通訊。它允許在點之間直接共享音訊、視訊和數據,無需中間伺服器,非常適合視訊會議、直播和檔案共享等應用程式。 在本部落格中,我們將深入探討以下主題: 什麼是WebRT...
    程式設計 發佈於2024-11-06
  • 如何在不使用 JavaScript 的情況下使用 CSS 隱藏和顯示內容?
    如何在不使用 JavaScript 的情況下使用 CSS 隱藏和顯示內容?
    使用CSS 隱藏和顯示內容:無需JavaScript 的技巧在進行Web 開發時,控制內容的可見性通常至關重要。傳統上,這是使用 JavaScript 實現的,但 CSS 也可用於創建優雅的隱藏和顯示效果。下面描述了一種此類技術,解決了先前方法遇到的特定挑戰。 隱藏/顯示內容切換:可以使用 CSS ...
    程式設計 發佈於2024-11-06
  • 如何建立重複最少的 5 個字元的隨機字串?
    如何建立重複最少的 5 個字元的隨機字串?
    產生5 個具有最少重複的隨機字元要建立具有最少重複的隨機5 個字元字串,最有效的方法之一是使用PHP 函數和巧妙技術的結合。讓我們深入研究解決方案:使用md5 和rand$rand = substr(md5(microtime()),rand(0,26),5);此方法使用md5雜湊函數根據時間戳記產...
    程式設計 發佈於2024-11-06
  • 如何在 Go 中處理不同套件之間相同的方法簽名?
    如何在 Go 中處理不同套件之間相同的方法簽名?
    處理不同套件中具有相同方法簽名的介面在Go中,當處理具有相同方法簽署但定義在不同套件中的多個介面時,可能會出現以下情況實作兩個介面的類型會導致意外行為。 考慮在不同套件中定義的這兩個介面(Doer)和函數(FuncA 和 FuncB):// Package A type Doer interface...
    程式設計 發佈於2024-11-06
  • 如何使用 jQuery 填充級聯下拉清單以獲得更好的相容性和使用者體驗?
    如何使用 jQuery 填充級聯下拉清單以獲得更好的相容性和使用者體驗?
    使用jQuery 填充級聯下拉清單在表單開發領域,級聯下拉清單經常用於提供更用戶友好和動態體驗。為了增強相容性並解決跨瀏覽器問題,jQuery 提供了一個強大的解決方案來非同步填充這些下拉清單。 問題中所示的用於建立級聯下拉清單的原始 JavaScript 函數缺乏與 IE 的兼容性。為了解決這個問...
    程式設計 發佈於2024-11-06
  • 了解 JavaScript 中的擴充運算子:初學者簡單指南
    了解 JavaScript 中的擴充運算子:初學者簡單指南
    介紹 JavaScript 是一種有趣的程式語言,其最令人興奮的功能之一是擴充運算子。如果您剛開始編碼,或者即使您是一個對學習 JavaScript 感興趣的孩子,也不必擔心!我將以最簡單的方式分解這個概念,並舉例來幫助您理解。 什麼是價差運算子? 擴充運算子看起...
    程式設計 發佈於2024-11-06
  • 在 Python 中使用 OpenSearch 掌握 CRUD 操作:實用指南
    在 Python 中使用 OpenSearch 掌握 CRUD 操作:實用指南
    OpenSearch, an open-source alternative to Elasticsearch, is a powerful search and analytics engine built to handle large datasets with ease. In this b...
    程式設計 發佈於2024-11-06
  • 冰沙框架的重要概念||如何精通冰沙
    冰沙框架的重要概念||如何精通冰沙
    要精通 Frappe,有几个关键概念和领域需要关注。以下是最重要的细分: 1. 文档类型 定义:DocTypes是Frappe中的核心数据模型。每个实体或记录都存储在 DocType 中,并且它们可以具有字段、权限和工作流程。 为什么它很重要:了解如何创建和自定义 DocType 至...
    程式設計 發佈於2024-11-06
  • 如何解決 JLabel 拖放的滑鼠事件衝突?
    如何解決 JLabel 拖放的滑鼠事件衝突?
    用於拖放的JLabel 滑鼠事件:解決滑鼠事件衝突為了在JLabel 上啟用拖放功能,滑鼠事件必須被覆蓋。然而,當嘗試使用 mousePressed 事件實作拖放時,會出現一個常見問題,因為 mouseReleased 事件對該 JLabel 無效。 提供的程式碼在 mousePressed 事件中...
    程式設計 發佈於2024-11-06
  • MySQL 中的資料庫分片:綜合指南
    MySQL 中的資料庫分片:綜合指南
    随着数据库变得越来越大、越来越复杂,有效地控制性能和扩展就出现了。数据库分片是用于克服这些障碍的一种方法。称为“分片”的数据库分区将大型数据库划分为更小、更易于管理的段(称为“分片”)。通过将每个分片分布在多个服务器上(每个服务器保存总数据的一小部分),可以提高可扩展性和吞吐量。 在本文中,我们将探...
    程式設計 發佈於2024-11-06
  • 如何將 Python 日期時間物件轉換為秒?
    如何將 Python 日期時間物件轉換為秒?
    在Python 中將日期時間物件轉換為秒在Python 中使用日期時間物件時,通常需要將它們轉換為秒以適應各種情況分析目的。但是,toordinal() 方法可能無法提供所需的輸出,因為它僅區分具有不同日期的日期。 要準確地將日期時間物件轉換為秒,特別是對於 1970 年 1 月 1 日的特定日期,...
    程式設計 發佈於2024-11-06

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3