看板 java 關於我們 聯絡資訊
※ 引述《kidd0730 (大阪掛川大不同)》之銘言: : google OR mapping後,對他的認知僅在於可以把撈出來資料暫存, : 然後可以像是直接對table操作一樣 用row和column去操作table : 那和我用rs.get後先放在Hashtable,再用Hashtable.get()的方式取得value再操作 : 以結果來看 2者都可以達到相同效果 : 那請問這2者有何差異呢? : 是效能上還是底層的運作不一樣呢 : 不都是先把table的資料先暫存起來嗎 要知道 Object-Relation Mapping 這個對應「工具」的來由, 需先思考物件導向語言描述一個世界的方法與關聯式資料庫的異同。 對物件導向語言來說, 它利用類別作為樣版來描述一個實體(instance)應有的欄位(field)與行為(method)。 對關聯式資料庫設計者來說, 透過觀察並抽象化資料,歸納需獨立存在的實體(entity)與相關屬性(attribute) 就這概略的描述來看,關聯與一個單純的類別(沒有繼承、沒有合成關係)差異並不顯著。 就這個層次來說,它們在設計上遭遇的共通問題 -- granularity 粒度, 如何找出一個最適當的大小,用它來構成一個類別(class)或實體(entity), 以至能合理地對應至真實世界,並用它來描述、處理我們的問題。 這問題可以留著設計著去煩惱,但物件導向語言擁有更多的語意, 這多出來的部分,正是您想瞭解的差異所在。 就以物件之間的關係來說,要如何在關聯式資料庫模擬出下列的情況呢? * 關聯 (association) * 合成 (composition) * 繼承與多形 * 群集 (collections) 關聯與合成在結構上相同,但在語意上就不同了。雖然都是一個類別內,再包一個類別: class Order { Customer customer; } class Customer { Address address; } 但對 Order 與 Customer 的關係來說,訂單取消了(如果要刪除的話), 客戶並不需要被刪除。 再看看 Customer 與 Address 的關係,如果客戶被刪除了,獨留地址是沒有意義的。 這語意上的問題,是 ORM 在設計時的一大挑戰。 (如果有 DB 達人就不要戰我了 :P 在實務上他們會強烈建立您設計為用「停用」來取代「刪除」 ) 然而,問題並不會只由物件導向體多出來的語意產生,另一個觀察的角度。 如何用物件體系描述一對一、多對一、一對多、多對多、弱個體等關係, 也是 ORM 設計時的挑戰。 若要提一些比較與 ORM 使用者相關的問題,那您必需注意的是: *「物件相等性」與「關聯表主鍵」對應的問題。 (Java 的 equals, hashCode 該怎麼對應至 PK 判定相等性) * 效能調整問題 (ex. 資料庫查詢 n+1) * 交易問題 (Long Conversation、並行層級) * 不同資料庫支援資料型別的問題 (Hibernate 用 Dialect 設計克服) * 即使有抽象化的查詢方式(ex. Hibernate Query Language), 也要知道哪些寫法會在資料庫轉移時會需要修改。 其實,使用 ORM 看似簡單,但要做到玩弄的它境界。 還需要徹底理解資料庫與 ORM 本身提供的能力。 撰寫 SQL 的複繁看似被隱藏了, 但得真誠的理解 ORM 帶來的新問題,才能與它和平共處。 ===================================================================== 以上是超濃縮版讀書心得,若想更深入瞭解 ORM, 可以參考 Hibernate 開發者 Gavin King 所著的書: Java Persistence with Hibernate Second Edition of Hibernate in Action Christian Bauer and Gavin King http://www.manning.com/bauer2/ -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 61.231.53.241
bala045:阿 第一本看過了 寫得很詳細 很複雜 06/27 11:56