自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

iBATIS with MapBean應(yīng)用淺析

開(kāi)發(fā) 后端
iBATIS with MapBean應(yīng)用的淺析向你介紹實(shí)際工作中的一點(diǎn)體會(huì),希望對(duì)你有一些啟發(fā)。

用了兩年的Hibernate之后,對(duì)ORM深有感觸。一方面,ORM可以令到我們從OO角度來(lái)思考數(shù)據(jù),屏蔽了數(shù)據(jù)庫(kù)的差異(其實(shí)Hibernate被吹的最厲害就是那個(gè)分頁(yè),其實(shí)分頁(yè)沒(méi)什么技術(shù)含量,而且ROR都把分頁(yè)從核心抽離了)。另一方面,性能問(wèn)題,例如必須select才能update,必須select全部,必須update全部,cache帶來(lái)的后遺癥,JavaBean關(guān)聯(lián)問(wèn)題(一對(duì)多,多對(duì)一,多對(duì)多等),lazyload問(wèn)題。當(dāng)然,小型項(xiàng)目是很有優(yōu)勢(shì)的

Hibernate一直說(shuō),他生成的sql比一般程序員的要好,可以減少很多問(wèn)題。但是,我倒是認(rèn)為用Hibernate反而因?yàn)閷?duì)程序員的要求更高導(dǎo)致更多問(wèn)題。而且我現(xiàn)在認(rèn)為,SQL才是王道,至少目前是。

于是在新項(xiàng)目中啟用iBATIS,這一年來(lái)的使用感覺(jué)很不錯(cuò),全程使用細(xì)粒度的SQL語(yǔ)句,雖然多寫了很多SQL語(yǔ)句,但是感覺(jué)到項(xiàng)目在自己的控制中

我只用了iBATIS 40%不到的功能,可能大家會(huì)覺(jué)得不可思議。我沒(méi)有用cache,沒(méi)有用關(guān)聯(lián),沒(méi)有用resultMap,甚至,連JavaBean也沒(méi)有用

在大家都在討論P(yáng)O,VO,DTO的時(shí)候,我的系統(tǒng)里面一個(gè)JavaBean都沒(méi)有

首先我問(wèn)問(wèn),JavaBean是用來(lái)做什么的,存儲(chǔ)數(shù)據(jù),每一個(gè)PO,其實(shí)就約等于一個(gè)表里面的一行數(shù)據(jù)

我舉一個(gè)真實(shí)一點(diǎn)的例子,一個(gè)user表

  1. public class User {  
  2.   private int id;  
  3.   private String name;  
  4.    
  5.   // 省略getter/setter一大段  

不知道大家有沒(méi)有用eclipse生成JavaBean getter/setter的痛苦,至少非??菰铩U麄€(gè)JavaBean實(shí)現(xiàn)了什么功能?完全沒(méi)有

好了我開(kāi)謎底了,我用的是HashMap

什么,HashMap?是不是聽(tīng)錯(cuò)了

沒(méi)聽(tīng)錯(cuò),請(qǐng)問(wèn)有什么事情是上面那個(gè)那么普通的JavaBean能做到的,而HashMap不能做到的呢

用HashMap沒(méi)有具體屬性的類型啊,那不是變成動(dòng)態(tài)語(yǔ)言一樣了,而且我要在JavaBean里面加邏輯怎么辦

好吧,這是我想到的兩個(gè)問(wèn)題(如果你也有別的問(wèn)題可以留意提出來(lái))

首先,現(xiàn)在不同以前了,動(dòng)態(tài)語(yǔ)言的優(yōu)勢(shì)慢慢提高了,像動(dòng)態(tài)語(yǔ)言有什么不好,我從ROR里面學(xué)了很多不錯(cuò)的思想

其次是要加邏輯怎么辦,這個(gè)問(wèn)題,之前在Javaeye討論充血模型還是貧血模型不可開(kāi)交,***還是沒(méi)什么結(jié)論,目前還是一片貧血的情況,你可以翻一下你的項(xiàng)目里面的JavaBean,至少大多數(shù)的Bean都是沒(méi)有意義的getter/setter。BO跟PO混雜在一起也很多人不建議的。至于邏輯,大可以寫在util包里面,我都把整個(gè)model包去掉了,強(qiáng)化一下util不成么,呵呵

再次,數(shù)據(jù)庫(kù)的列,跟JavaBean的屬性兩者,本來(lái)就是冗余的,如果我們修改數(shù)據(jù)庫(kù)結(jié)構(gòu),就還要修改相應(yīng)的JavaBean,或者影射文件。當(dāng)然我這種做法更依賴數(shù)據(jù)庫(kù)。另外,ROR的名字轉(zhuǎn)換功能可以令到代碼中的調(diào)用名字更好看一些,我覺(jué)得也不是非常有必要的實(shí)現(xiàn)

直接使用HashMap不太方便,尤其是類型轉(zhuǎn)換上,于是我實(shí)現(xiàn)了一個(gè)MapBean的類,其實(shí)這個(gè)類很簡(jiǎn)單,關(guān)鍵是用HashMap代替JavaBean的思想

  1. public class MapBean extends HashMap﹤String, Object﹥ {  
  2.  public MapBean() {  
  3.  }  
  4.    
  5.  public MapBean(Object... args) {  
  6.   put(args);  
  7.  }  
  8.    
  9.  public int getInt(Object key) {  
  10.   return getInt(key, 0);  
  11.  }  
  12.    
  13.  public int getInt(Object key, int defaultInt) {  
  14.   Integer i = (Integer) get(key);  
  15.   return i == null ? defaultInt : i;  
  16.  }  
  17.    
  18.  public String getString(Object key) {  
  19.   return (String) get(key);  
  20.  }  
  21.    
  22.  public String getString(Object key, String defaultValue) {  
  23.   String value = (String) get(key);  
  24.   return value == null ? defaultValue : value;  
  25.  }  
  26.    
  27.  public Timestamp getTimestamp(Object key) {  
  28.   return (Timestamp) get(key);  
  29.  }  
  30.    
  31.  public void put(Object... args) {  
  32.   for (int i = 1; i ﹤ args.length; i += 2) {  
  33.    put(String.valueOf(args[i - 1]), args[i]);  
  34.   }  
  35.  }  
  36.    
  37.  public JSONObject toJson() {  
  38.   return JSONObject.fromObject(this);  
  39.  }  
  40.    
  41.  public JSONObject toJson(String... keys) {  
  42.   xxx  
  43.  }  
  44.    
  45.  public String toJsonString() {  
  46.   return toJson().toString();  
  47.  }  

這個(gè)類主要是方便做類型轉(zhuǎn)換,加入了getInt,getString等方法,另外因?yàn)槲业南到y(tǒng)里面大量使用了JSON,也有一些HashMap向JSON轉(zhuǎn)換的輔助方法,還有一個(gè)特別處理過(guò)的put方法和構(gòu)造器,有什么用呢,看下面的例子

  1. MapBean params = new MapBean("id",userId,"name",username,"sex",0,"online",true); 

如果你直接用HashMap實(shí)現(xiàn)以上功能,要寫五行代碼,就這個(gè)差別而已,呵呵

當(dāng)然如果你用JavaBean的話,你也可以寫一個(gè)對(duì)應(yīng)的構(gòu)造函數(shù)

接下來(lái),我們?cè)趕ql-map-config.xml中加入

  1. ﹤typeAlias alias="mapbean" type="xxxxxxx.MapBean" /﹥ 

就可以用mapbean的別稱來(lái)引用這個(gè)類了

例如具體的SQL xml是這樣的

  1. select id="getWorkManagerSystemRole" resultClass="mapbean" 
  2.  parameterClass="mapbean"﹥  
  3.  select * from work_manager_system_role where 
  4.  system_id=#system_id# and user_id=#user_id#  
  5. ﹤/select﹥ 

其實(shí)我已經(jīng)把iBATIS當(dāng)成SQL wrapper來(lái)用了,我曾經(jīng)評(píng)估過(guò)Spring的JDBC Template,不過(guò)功能始終差少少,或許以后我把JDBC Template再?gòu)?qiáng)化一下來(lái)代替iBATIS吧。

iBATIS with MapBean應(yīng)用的淺析就向你介紹到這里,希望對(duì)你有所幫助。

【編輯推薦】

  1. iBATIS使用之高級(jí)查詢技術(shù)詳解
  2. iBATIS分頁(yè)源碼真相探討
  3. iBATIS教程之入門淺析
  4. Hibernate與iBATIS的較量淺析
  5. iBATIS實(shí)例創(chuàng)建的五大步淺析
責(zé)任編輯:仲衡 來(lái)源: 網(wǎng)易博客
相關(guān)推薦

2009-07-17 10:59:59

iBATIS接口

2009-07-16 13:08:09

iBATIS快速創(chuàng)建應(yīng)

2009-07-21 11:12:00

iBATIS配置

2009-07-22 11:11:39

iBATIS分頁(yè)實(shí)例ObjectDataS

2009-07-15 17:58:07

iBATIS 動(dòng)態(tài)映射

2009-07-16 10:23:30

iBATIS工作原理

2009-07-22 10:42:59

iBATIS Cach

2009-07-22 10:03:11

iBATIS Resu

2009-07-16 09:14:26

iBATIS DAO

2009-07-20 18:00:16

iBATIS DAO事

2009-07-15 17:19:31

iBATIS Ecli

2009-07-22 16:02:14

iBATIS參數(shù)

2009-07-17 09:44:40

iBATIS教程

2009-07-22 15:01:01

iBATIS SQLM

2009-07-17 17:05:44

iBATIS緩存cacheModel

2009-07-22 15:21:00

iBATIS SQLM

2009-07-22 09:44:05

iBATIS Para

2009-07-15 16:42:03

iBATIS讀寫CLO

2009-07-22 16:43:22

iBATIS框架iBATIS優(yōu)化

2009-07-22 09:07:01

iBATIS.NET
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)