iBATIS with MapBean应用浅析
创始人
2024-04-17 04:01:49
0

用了两年的Hibernate之后,对ORM深有感触。一方面,ORM可以令到我们从OO角度来思考数据,屏蔽了数据库的差异(其实Hibernate被吹的最厉害就是那个分页,其实分页没什么技术含量,而且ROR都把分页从核心抽离了)。另一方面,性能问题,例如必须select才能update,必须select全部,必须update全部,cache带来的后遗症,JavaBean关联问题(一对多,多对一,多对多等),lazyload问题。当然,小型项目是很有优势的

Hibernate一直说,他生成的sql比一般程序员的要好,可以减少很多问题。但是,我倒是认为用Hibernate反而因为对程序员的要求更高导致更多问题。而且我现在认为,SQL才是王道,至少目前是。

于是在新项目中启用iBATIS,这一年来的使用感觉很不错,全程使用细粒度的SQL语句,虽然多写了很多SQL语句,但是感觉到项目在自己的控制中

我只用了iBATIS 40%不到的功能,可能大家会觉得不可思议。我没有用cache,没有用关联,没有用resultMap,甚至,连JavaBean也没有用

在大家都在讨论PO,VO,DTO的时候,我的系统里面一个JavaBean都没有

首先我问问,JavaBean是用来做什么的,存储数据,每一个PO,其实就约等于一个表里面的一行数据

我举一个真实一点的例子,一个user表

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

不知道大家有没有用eclipse生成JavaBean getter/setter的痛苦,至少非常枯燥。整个JavaBean实现了什么功能?完全没有

好了我开谜底了,我用的是HashMap

什么,HashMap?是不是听错了

没听错,请问有什么事情是上面那个那么普通的JavaBean能做到的,而HashMap不能做到的呢

用HashMap没有具体属性的类型啊,那不是变成动态语言一样了,而且我要在JavaBean里面加逻辑怎么办

好吧,这是我想到的两个问题(如果你也有别的问题可以留意提出来)

首先,现在不同以前了,动态语言的优势慢慢提高了,像动态语言有什么不好,我从ROR里面学了很多不错的思想

其次是要加逻辑怎么办,这个问题,之前在Javaeye讨论充血模型还是贫血模型不可开交,***还是没什么结论,目前还是一片贫血的情况,你可以翻一下你的项目里面的JavaBean,至少大多数的Bean都是没有意义的getter/setter。BO跟PO混杂在一起也很多人不建议的。至于逻辑,大可以写在util包里面,我都把整个model包去掉了,强化一下util不成么,呵呵

再次,数据库的列,跟JavaBean的属性两者,本来就是冗余的,如果我们修改数据库结构,就还要修改相应的JavaBean,或者影射文件。当然我这种做法更依赖数据库。另外,ROR的名字转换功能可以令到代码中的调用名字更好看一些,我觉得也不是非常有必要的实现

直接使用HashMap不太方便,尤其是类型转换上,于是我实现了一个MapBean的类,其实这个类很简单,关键是用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.  }  

这个类主要是方便做类型转换,加入了getInt,getString等方法,另外因为我的系统里面大量使用了JSON,也有一些HashMap向JSON转换的辅助方法,还有一个特别处理过的put方法和构造器,有什么用呢,看下面的例子

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

如果你直接用HashMap实现以上功能,要写五行代码,就这个差别而已,呵呵

当然如果你用JavaBean的话,你也可以写一个对应的构造函数

接下来,我们在sql-map-config.xml中加入

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

就可以用mapbean的别称来引用这个类了

例如具体的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﹥ 

其实我已经把iBATIS当成SQL wrapper来用了,我曾经评估过Spring的JDBC Template,不过功能始终差少少,或许以后我把JDBC Template再强化一下来代替iBATIS吧。

iBATIS with MapBean应用的浅析就向你介绍到这里,希望对你有所帮助。

【编辑推荐】

  1. iBATIS使用之高级查询技术详解
  2. iBATIS分页源码真相探讨
  3. iBATIS教程之入门浅析
  4. Hibernate与iBATIS的较量浅析
  5. iBATIS实例创建的五大步浅析

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...