對象關係映射(ORM)

来源:https://www.cnblogs.com/manshufeier/archive/2018/07/23/9356700.html
-Advertisement-
Play Games

1、什麼是 對象-關係映射 對象-關係映射(Object Relational Mapping,簡稱ORM,對象關係映射)是一種為瞭解決面向對象與關係資料庫存在的互不匹配的現象的技術。 簡單的說,ORM是通過使用描述對象和資料庫之間映射的元數據,將程式中的對象自動持久化到關係資料庫中。本質上就是將數 ...


1、什麼是 對象-關係映射

  對象-關係映射(Object Relational Mapping,簡稱ORM,對象關係映射)是一種為瞭解決面向對象與關係資料庫存在的互不匹配的現象的技術。 簡單的說,ORM是通過使用描述對象和資料庫之間映射的元數據,將程式中的對象自動持久化到關係資料庫中。本質上就是將數據從一種形式轉換到另外一種形式。

  對象-關係映射(Object/Relation Mapping,簡稱ORM),是隨著面向對象的軟體開發方法發展而產生的。面向對象的開發方法是當今企業級應用開發環境中的主流開發方法,關係資料庫是企業級應用環境中永久存放數據的主流數據存儲系統。對象和關係數據是業務實體的 兩種表現形式,業務實體在記憶體中表現為對象,在資料庫中表現為關係數據。記憶體中的對象之間存在關聯和繼承關係,而在資料庫中,關係數據無法直接表達多對多 關聯和繼承關係。因此,對象-關係映射(ORM)系統一般以中間件的形式存在,主要實現程式對象到關係資料庫數據的映射。

  對象-關係映射(Object/Relation Mapping,簡稱ORM),是隨著面向對象的軟體開發方法發展而產生的。面向對象的開發方法是當今企業級應用開發環境中的主流開發方法,關係資料庫是企業級應用環境中永久存放數據的主流數據存儲系統。對象和關係數據是業務實體的 兩種表現形式,業務實體在記憶體中表現為對象,在資料庫中表現為關係數據。記憶體中的對象之間存在關聯和繼承關係,而在資料庫中,關係數據無法直接表達多對多 關聯和繼承關係。因此,對象-關係映射(ORM)系統一般以中間件的形式存在,主要實現程式對象到關係資料庫數據的映射。

  讓我們從O/R開始。字母O起源於"對象"(Object),而R則來自於"關係"(Relational)。幾乎所有的程式裡面,都存在對象和關係資料庫。在業務邏輯層和用戶界面層中,我們是面向對象的。當對象信息發生變化的時候,我們需要把對象的信息保存在關係資料庫中。

  一般的ORM包括以下四部分: 
      一個對持久類對象進行CRUD操作的API; 
      一個語言或API用來規定與類和類屬性相關的查詢; 
      一個規定mapping metadata的工具; 
      一種技術可以讓ORM的實現同事務對象一起進行dirty checking(臟檢查), lazy association fetching(惰性關聯抓取)以及其他的優化操作。

2、目前流行的 ORM 產品

      目前眾多廠商和開源社區都提供了持久層框架的實現,常見的有:      Apache OJB (http://db.apache.org/ojb/) 

      Cayenne (http://objectstyle.org/cayenne/) 

      Jaxor (http://jaxor.sourceforge.net) 

      Hibernate (http://www.hibernate.org) 

      iBatis (http://www.ibatis.com) 

      jRelationalFramework (http://ijf.sourceforge.net) 

      mirage (http://itor.cq2.org/en/oss/mirage/toon) 

      SMYLE (http://www.drjava.de/smyle) 

      TopLink (http://otn.oracle.com/products/ias/toplink/index.html)      其中 TopLink 是 Oracle 的商業產品,其他均為開源項目。      其中 Hibernate 的輕量級 ORM 模型逐步確立了在 Java ORM 架構中領導地位,甚至取代複雜而又繁瑣的 EJB 模型而成為事實上的 Java ORM 工業標準。而且其中的許多設計均被 J2EE 標準組織吸納而成為最新 EJB 3.0 規範的標準,這也是開源項目影響工業領域標準的有力見證。

3、對象-關係映射模式

  (1)數據類型映射模式

  • 簡單數據類型模式:建立UML和關係型資料庫中簡單數據類型的映射表以指導映射。

  • 枚舉數據類型模式:每種枚舉類型對應一個表,只有一個列(_EnumLiteral)表示枚舉值。

  • 基於類的數據類型模式:使用外鍵約束,將基礎列與基於類的類型實例相關聯。

  (2)類映射模型

      每個類對應一個表。單值屬性、多值屬性、繼承關係可以用下述方法映射,而引用屬性將在關聯映射模式中提到。

  • 單值屬性模式:是cardinality的上界為1的屬性,映射到類所對應的表的列上。若其下界也為1(必須有的屬性),列屬性為NOT NULL。
  • 多值屬性模式:每個多值屬性映射成一個獨立的表,使用外鍵連接到類所對應的表上。

  • 繼承模式:每加入一個類的實例時,根據其繼承關係自頂向下生成每個類的對象,這些對象具有相同的ID(根對象對應記錄的主鍵)。刪除對象實例時,自底向上刪除數據。

  (3)關聯映射模式

  • 一對一關聯模式:在關聯兩端各加一列。

  • 一對多關聯模式:如果多這端是有序的,還需加入一列表示序號。

  • 多對多關聯模式:將關聯單獨作一個表。

  • 組合關聯模式:註意級聯式刪除。

  • 反演關聯模式:關聯兩端指向相關的類型,和普通關聯一樣。

  • 成對關聯模式:關聯記錄兩個類間的關係,用交集類表示關聯,表示成一個單獨的表,每個關聯對應一個表,用外鍵表示它們間的關係。

  • 關聯上的OCL需要分析成對應的存儲過程代碼。

  • 保證關聯的cardinality也需要分析成對應的存儲過程代碼。

  (4)引用映射模式

  • 在UML中不存在的MOF特征,指屬性是聲明為引用類型的實例。用存儲過程實現。

4、SQL與ORM的優缺點

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

  • ORM優點
    • 方便地使用面向對象,語句清晰

    • 防註入『這個其實不算ORM的核心,因為比如Phalcon的SQL形式寫法也可以防註入』

    • 方便動態構造語句,對於不同的表的相同操作採用多態實現更優雅

    • 一定程度方便重構數據層『比如改表名,欄位名等』

    • 設置鉤子函數

  • ORM缺點
    • 不太容易處理複雜查詢語句
    • 性能較直接用SQL差

5、如何選擇

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

  • Model對象不確定的時候,使用多態的方式去處理不同實例的相同操作

  • 語句結構不確定的時候,比如根據不同的情況Where子句不一樣的時候,採用if的代碼結構去控制ORM方法的使用比拼接SQL語句要清晰的多

  • 設置鉤子函數,比如分頁裡面,拿分頁數據同時要count數據,那麼就可以在Model裡面插入這個算count的鉤子函數(包括緩存邏輯)


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 超好用超短的小程式請求封裝,也不算特別特別短吧哈哈哈。但真的很好用的一個小程式請求封裝,在請求的時候簡短提高效率不需要將一樣的東西重覆寫。下麵就讓大家看看這個封裝是有多短,不夠短的話也請別打我 網上多數使用的小程式封裝是在單獨的一個js文件,再使用module.exports進行輸出方法。我所介紹的 ...
  • 導航欄 JQ代碼 ...
  • 在javscript中,this 是在函數運行時自動生成的一個內部指針,它指向函數的調用者。 箭頭函數有些不同,它的this是繼承而來, 預設指向在定義它時所處的對象(宿主對象),而不是執行時的對象。 如上getName3(),將箭頭函數作為直接執行的方法來寫時要特別小心,它的this會直接指向wi ...
  • 一,效果圖。 二,代碼。 參考資料:《菜鳥教程》 ...
  • 通過axios請求介面已經很簡單了,但最近在做一個vue項目,想著把axios請求再封裝一下,這樣api就可以只在一處配置成方法,在使用的時候直接調用這個方法。 但咱們不用每個介面都定義成一個啰嗦的axios請求方法,既然是想簡單點,就儘量只在一處完成簡單的配置。 1、配置api介面 將同一模塊的接 ...
  • 1、應用架構為什麼要分層 先看應用不分層有什麼缺點: 代碼不夠清晰,難以閱讀。 代碼職責不明,難以擴展。 代碼錯綜複雜,難以維護。 代碼沒做分工,難以組織。 分層有什麼特點: 按業務功能進行分層。 層次關係良好,上層依賴下層,下層支撐上層,下層不能訪問上層。 每一層都能保持獨立。 一般應用使用三層架 ...
  • 最近很長時間沒寫博客了,其實這個博客寫過一半,中間有事耽擱了,就沒繼續。主要是給別人做了一個小系統,及維護碼雲上的代碼庫。同居的日子也占了我很多時間。 最近也是煩,欠了7W,各種煩事。所以可想寫個博客靜靜心。 在面向對象中關註的焦點是對象空間,對象與對象的聯繫還是通過保存引用(相當於路),來走到其空 ...
  • 目的是為了可維護、可復用、可擴展、靈活性好 以四則運算為例: 先有個父類運算類: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...