資料映射器或服務層應該處理複雜的查詢條件嗎?
這個問題出現在涉及多個條件的複雜查詢的上下文中。資料映射器模式旨在促進資料庫交互,通常提供通用的 get() 方法,用於根據指定條件檢索資料。然而,在需要更複雜查詢的場景中,會出現對這些條件的適當處理的擔憂。
一種方法涉及擴展資料映射器的 get() 方法以接受多個條件。這允許服務層直接調用擴展方法,將其角色減少為純粹的中介。相反,替代方法使服務層能夠在呼叫傳遞多個條件的通用 get() 方法之前解析條件。這將條件邏輯轉移到服務層,使資料映射器具有更簡單的實作。
雖然服務層方法確保了模型層中域邏輯的包含,但它可能會損害資料映射器的主要目的模式,用於處理資料庫互動。有些人認為映射器應該保持簡單,專注於資料檢索和存儲,而服務層則負責管理複雜的查詢並確保遵守業務規則。
或者,資料映射器方法保持與映射器處理資料操作,服務層負責更高層級的任務。映射器可以擴展為包含為處理特定條件組合而自訂的方法,例如 getByAuthorAndPublisher()。這種方法將服務層的角色簡化為協調器,將大部分條件邏輯委託給域物件本身。
最終,這些方法之間的選擇取決於應用程式的複雜性、所需等級等因素資料檢索的粒度以及團隊的偏好。沒有普遍接受的解決方案,但了解權衡並考慮應用程式的上下文將幫助開發人員確定適合其特定用例的最合適的方法。
以上是複雜查詢條件應該放在哪裡:資料映射器還是服務層?的詳細內容。更多資訊請關注PHP中文網其他相關文章!