java 板


LINE

※ 引述《gasbomb (虛空雷神獸)》之銘言: : 大家好, 小弟 java 新手 : 個人的第一個作品因為缺乏經驗當初做得苦不堪言 : 肥胖商務層處理完資料後 : 一行一行的把資料填進 VO 裡面 : 到了 DAO 又要一行一行的把資料填入 PreparedStatement : 寫起來既枯燥又充滿重複的程式碼 : 後來才了解到這其實是一種 Anemic Domain Model (貧血領域模型) : 最近練習刻新系統, 取消商務層的設計只保留部分的 service : 讓大部分的邏輯進入物件, 看看可不可以讓自己的系統充血一點 : 但是現在遇到了一些設計上的問題 : 假設今天有一家麵包店 : ┌───────┐ ┌────┐ : │bread_category│ │bread  │ : ╞═══════╡ ╞════╡ : │cid (PK)←──┼┐│bid (PK)│ : │cname     │└┼cid (FK)│ : │......    │ │...... │ : └───────┘ └────┘ : bread 是麵包(廢話) : bread_category 是麵包分類 : 今天的邏輯是 cid 可以刪除 : 刪除以後該分類下面所有的麵包全部移到未分類 cid = 0 底下 : 這件事情在 DB 上面做非常簡單, 只要兩行指令就搞定了 : UPDATE bread SET cid = 0 WHERE cid = 1; : DELETE FROM bread_category WHERE cid = 1; : 因為這是 DB 的操作, 所以在 DAO 裡面寫一個方法讓物件使用也是很合理的 : 但是當我準備這麼作時卻有一種不安的感覺浮上心頭, 覺得自己好像已經破壞了什麼規 : 照理說更改麵包分類是事務邏輯, 應該在 model 層處理, DAO 只負責資料存取 : 從相依性的角度來說, DAO 寫太多東西進去也會加重日後換 DB 的負擔 : 所以我可能會在 model 這樣寫 : new Bread().getAll().stream() : .filter(bread -> bread.getCID() == 1) : .forEach(bread -> { : bread.setCID(0); : bread.update(); : }); : 這樣打開麵包原始碼所有功能一目了然, 日後也方便修改 : 但是為了刪除一個 cid 叫出所有麵包好像哪裡怪怪的 : 叫所有麵包一起更新也會占用大量的資料庫連線 (當初沒考慮到大量更新的需求) : 為了解決上面的問題在 DAO 另外寫兩個方法 : 一個是用 cid 查詢麵包 : 一個是大量更新麵包...... : 這樣看起來好像兼顧邏輯跟效能, 可是 DAO 肥大的問題又回來了啊~~~~(崩潰) : 而且這樣需要寫的程式更多 : 那我還不如回去寫那兩行 SQL 指令 : 雖然我知道這間麵包店可能一輩子都不會有效能瓶頸的問題 : 不過上面的問題確實已經困擾我一天了 : google 找到的也都是一些很 general 的, 介紹設計模式的文章 : 不知道大家在遇到這種問題的時候都是如何決策的? : 如果今天是我的案例, 大家會用哪一種方案解決呢? 原文兩位推文在說的還是DB 實作上的取捨, OP煩惱的是Anemic model vs behaviorial-rich model . 我相信你應該有看一些Domain Driven Design (DDD)的入門?單看你的code 有些詭異: 正常設計不會new Bread().getAll() 去取, Model 本身不負責update自己(可能你誤解 Anemic model的問題了?) 存取層該是Repository 而不叫DAO 。 回到你的問題,首先你這個”移動category” 的 行為打算放在哪個domain model?假設你有個叫 BreadShop 的model (沒有合用的Model 可以弄個Domain Service, 詳見DDD). 東西大概會長這樣(pseudo code): class BreadShop { void cancelCategory(Category cat, Category moveTo) { // 假設你Category 有指向它擁有的包 cat.moveBreadsTo(moveTo); breadCategoryRepo.update(moveTo); breadCategoryRepo.remove(cat); //又或者長這樣 breads=breadRepo.findByCategory(cat); for b in breads bread.putToCaregory(moveTo); // 諸如此類 } } 重點是這個動作也是放在Domain 層內,假 設後來你發現真的太慢,也只需要在Repo 內提供bulk update 的功能,但domain 所 Expose 的API 仍然可以維持不變。 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 223.19.42.108 (香港)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/java/M.1560382410.A.3BD.html
1F:推 dream1124: 推 06/16 11:50







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:iOS站內搜尋

TOP