java - 阿里的開發(fā)手冊中為什么禁用map來作為查詢的接受類?
問題描述
我在項目中經(jīng)常使用List<Map<String,Object>>做為查詢的接受對象.感覺使用方便,不用每個多表查詢的時候都創(chuàng)建DTO類.
上面只針對查詢,如果將map應(yīng)用到DTO,VO是否會有相同的問題.
問題解答
回答1:1、map參數(shù)數(shù)量大時不易維護。要通過識別字符串形式的key,可能哪個字母沒加程序就出錯了
2、map轉(zhuǎn)成實體,耗費資源。或者不轉(zhuǎn)實體,直接將map傳到sql層,但要判斷空值(傳沒傳這個參數(shù)啊。。。),參數(shù)數(shù)量一多要加一堆判斷(sql效率下降,也不易維護)
3、創(chuàng)建map再put進參數(shù)值,比創(chuàng)建一個實體類的時間要長(map數(shù)量少時創(chuàng)建的時間差距很小,但是數(shù)量較大時差距會非常大)
4、參數(shù)類型的控制。sql中不是字符串類型的參數(shù)還要轉(zhuǎn)成數(shù)值。。。錯誤跑到sql中,容易被CC
5、面相對象,將sql層與實體分離,降低耦合。否則維護很麻煩
回答2:我認為有兩個方面吧:1.面向?qū)ο蟮乃枷?.效率吧,畢竟玩查詢的【這里的效率是指map.get(key)】,map.put然后get的 這樣很容易出錯吧, 的確不怎么好
都是我瞎編的,呵呵,大學(xué)老師好像講過吧。。
回答3:不利于他人共同開發(fā)和后期維護
回答4:Map<String, Object> 類型不安全
回答5:Map用查詢參數(shù),方法調(diào)用者根本就不知道方法提供者提供方法參數(shù)可以存哪些健值對以及健值對類型,map.put(key,value)亂傳的問題不能在編譯階段發(fā)現(xiàn),用QueryDto可以精確定義參數(shù)類型和限制(JSR 303 Validation)
回答6:如果我沒有理解錯誤的話.
數(shù)據(jù)查詢對象是指 dao 查詢方法的參數(shù)封裝, 并不是指方法的返回. 這樣做的好處是代碼的可讀性高, 你直接使用map作為接口參數(shù), 使用者想要確定具體的查詢條件非常困難, 而且給外部接口調(diào)用的靈活性太高, 比如 使用者在map中增加一個x, 但是你的查詢根本不支持, 但是你如何讓使用者能夠確認的知道呢?
而 dao 的返回參數(shù)按照文檔的要求是應(yīng)該使用 do/dto.
回答7:感覺主要是調(diào)試和維護困難,比如任何key的拼寫錯誤,要到query執(zhí)行時才能反饋
回答8:map的優(yōu)點:
1、靈活性強于javabean,易擴展,耦合度低。2、寫起來簡單,代碼量少。
看一看Javabean的優(yōu)點:
1、面向?qū)ο蟮牧己迷忈尅?、數(shù)據(jù)結(jié)構(gòu)清晰,便于團隊開發(fā) & 后期維護。3、代碼足夠健壯,可以排除掉編譯期錯誤。
權(quán)衡利弊,如果團隊開發(fā)還是javabean比較好,個人項目就無所謂了。歡迎補充!~
相關(guān)文章:
1. javascript - vuejs+elementui 購物車價格計算,點擊加減號修改數(shù)量總價都不會改變,但是計算執(zhí)行了2. css右浮動字的順序顛倒了3. MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)4. html5和Flash對抗是什么情況?5. javascript - 我是做web前端的,公司最近有一個項目關(guān)于數(shù)據(jù)統(tǒng)計的!6. ios - 類似微博首頁,一張圖的時候是如何確定圖大小的?7. javascript - 如何使用loadash對[object,object,object]形式的數(shù)組進行比較8. javascript - vue過渡效果 css過渡 類名的先后順序9. javascript - 在ie下為什么會出現(xiàn)這種情況呢 《 無法獲取未定義或 null 引用的屬性“l(fā)ength”》 ?請大神指教。10. 數(shù)據(jù)庫 - Mysql的存儲過程真的是個坑!求助下面的存儲過程哪里錯啦,實在是找不到哪里的問題了。
