SQL與ORM的優缺點

相對來說,ORM的缺點就是SQL的優勢地方,而優點也是SQL的劣勢地方。

  • 優點
    • 方便的使用面向對象,語句清晰
    • 防注入『這個其實不算ORM的核心,因爲比如Phalcon的SQL形式寫法也可以防注入』
    • 方便動態構造語句,對於不同的表的相同操作採用多態實現更優雅
    • 一定程度方便重構數據層『比如改表名,字段名等』
    • 設置鉤子函數
  • 缺點
    • 不太容易處理複雜查詢語句
    • 性能較直接用SQL差

如何選擇

儘量使用ORM,除了含子查詢的複雜語句『不過大流量下的網站最好不要寫這種複雜SQL』,當然這也只是一個原則,所以反過來說也可以,不過以下幾個場景用ORM的好處是很明顯的

  • Model對象不確定的時候,使用多態的方式去處理不同實例的相同操作
  • 語句結構不確定的時候,比如根據不同的情況Where子句不一樣的時候,採用if的代碼結構去控制ORM方法的使用比拼接SQL語句要清晰的多
  • 設置鉤子函數,比如分頁裏面,拿分頁數據同時要count數據,那麼就可以在Model裏面插入這個算count的鉤子函數(包括緩存邏輯)



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章