`
zgd
  • 浏览: 8608 次
  • 性别: Icon_minigender_1
  • 来自: 广州
最近访客 更多访客>>
社区版块
存档分类
最新评论

[原创]Ibatis with MapBean

阅读更多
用了两年的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表
public class User {
  private int id;
  private String name;
 
  // 省略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的思想
public class MapBean extends HashMap<String, Object> {
	public MapBean() {
	}
 
	public MapBean(Object... args) {
		put(args);
	}
 
	public int getInt(Object key) {
		return getInt(key, 0);
	}
 
	public int getInt(Object key, int defaultInt) {
		Integer i = (Integer) get(key);
		return i == null ? defaultInt : i;
	}
 
	public String getString(Object key) {
		return (String) get(key);
	}
 
	public String getString(Object key, String defaultValue) {
		String value = (String) get(key);
		return value == null ? defaultValue : value;
	}
 
	public Timestamp getTimestamp(Object key) {
		return (Timestamp) get(key);
	}
 
	public void put(Object... args) {
		for (int i = 1; i < args.length; i += 2) {
			put(String.valueOf(args[i - 1]), args[i]);
		}
	}
 
	public JSONObject toJson() {
		return JSONObject.fromObject(this);
	}
 
	public JSONObject toJson(String... keys) {
		xxx
	}
 
	public String toJsonString() {
		return toJson().toString();
	}
}

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

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

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

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

接下来,我们在sql-map-config.xml中加入
<typeAlias alias="mapbean" type="xxxxxxx.MapBean" />

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

例如具体的SQL xml是这样的
<select id="getWorkManagerSystemRole" resultClass="mapbean"
	parameterClass="mapbean">
	select * from work_manager_system_role where
	system_id=#system_id# and user_id=#user_id#
</select>

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

http://weavesky.com/2008/01/29/ibatis-with-mapbean/
分享到:
评论
49 楼 crazyox 2008-02-25  
感觉又变成选择hibernate与ibatis的争论上了。。。

存在即合理, 什么东西都不是绝对的, 楼主这样封装自会有他的道理, 也有可能有自己能派上用场的地方, 用什么都无所谓,根据环境而定, 还是找一个适合自己的吧!
48 楼 jiakechong 2008-02-24  
没用过hibernate,感觉比较复杂, 我还是用ibatis,感觉不错
47 楼 littledodo 2008-02-20  
学习, 打算用ibatis
46 楼 wq163 2008-02-19  
sunwei_07 写道
我现在喜欢使用JdbcTemplate,外加自己封装的FormBean工具,使用也挺顺手
Ibatis我其实很喜欢,但是由于水平有限,实在不知道很好的怎么解决其中的分页方法


让Ibatis支持物理分页在这个论坛上有的,实现自己的SqlExecutor ,在获取sqlMap的时候反射进去。不影响其他代码。我在一个项目中就这样用过了,非常好用
那篇主题叫《使ibatis支持hibernate式的物理分页》,现在已经不在了
45 楼 gumpgz 2008-02-18  
maku 写道
引用
我只用了Ibatis 40%不到的功能,可能大家会觉得不可思议。我没有用cache,没有用关联,没有用resultMap,甚至,连JavaBean也没有用

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

...

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

在我的项目里大量的使用 resultMap,JavaBean和Map,究竟使用JavaBean还是Map要看具体情况,不能以偏盖全。
eclipse生成JavaBean getter/setter的过程并不痛苦,因为那是工作的一部分;不谈
getter/setter的用处及设计意图,起码他是J2EE规范的一部分,J2EE就是一些约定俗成的规范,你的程序规范,别人阅读和维护起来就容易一些。

感觉楼主似乎厌倦了这些,你可以使用动态语言实现你的想法,但最好别拿java语言开刀。



确实是,现在各种框架、产品都不是万金油,优缺点都很明显。想要一招鲜吃遍天还是有些困难的,关键是怎样扬长避短,总是争论某几个产品的孰优孰劣也没有实际意义。

1、完全抛弃javabean也不一定是好事,面向对象的思想提出不是一天两天了,还是经得起考研的。当然,全用map也未尝不可,早期我们的项目也是这种做法。
2、javabean的生成也不是复杂的事情,hibernate、ibatis都提供了javabean的生成方法和插件,都符合javabean的标准定义,基本可以通用,再不济自己可以写一套javabean生成方法,建库完了生成就是了。
3、至于分页,ibatis的分页已经不推荐使用。我自己仿照hibernate的做法,利用数据库的特性,做了个分页程序,适用于oracle、db2、sql server2005、mysql,因为这些数据库都提供了rownum(直接或者间接)这个保留字。下一步打算融合到ibatis中。
4、ibatis不适合移植,这个确实是问题。我在ibm开发专区看到过有人写的实现方案,是每种数据库都写一个map文件,可以自动判断数据库类型读取文件。后来,我想了一下,有个变通的做法,可以在map文件对特殊sql(不具有移植性的)针对每种数据库都写一套,然后命名成不同的名字,如"queryUserList"、"queryUserList#db2"、"queryUserList#oracle"累死这种,修改ibatis的加载机制,根据数据库类型不同自动读取对应的sql信息,这样能减少map配置文件,也便于维护。此修改也正在实施中。

个人观点,欢迎讨论
44 楼 yyjn12 2008-02-18  
1314520ln 写道
看来你还没真正了解hibernate


你了解那就请你说说
43 楼 96sd2 2008-02-16  
这种思路的确值得借鉴
42 楼 xfan1982 2008-02-15  
我就是用map搞定一切
41 楼 rtm 2008-02-15  
HashMap代替JavaBean的唯一缺点就是没有类型安全,HashMap满天飞.
受限于静态语言,这个是没有办法的.
如果是动态语言来实现Hibernate或者Ibatis,我相信会更加的灵活.比如分页,用Oracle的rownum分页,需要计算firstrow,lastrow,现在迫不得已只能让参数类继承一个Page类,里面有firstrow,lastrow两个字段,如果是动态语言,多爽啊,动态加上两个字段,用完了删除,外面的参数类干干净净
40 楼 yao_2110 2008-02-15  
leebai 写道
基本赞成楼主的观点,OR Maping是典型的穷折腾。

加个前提,再不需要可移植性的情况下。。。

多数情况不需要可移植性,大家关注的都是性能。。。这个时候用hibernate是自找麻烦,不是hibernate做得不好。。。
39 楼 dingdangxiaoma 2008-02-12  
学习了...
38 楼 louisling 2008-02-04  
对 ORM 的讨论永远都没有结束...
每个人都有不同的思路, 不同的实现.

我的想法是, 封装 Spring 的 SimpleJdbcTemplate, 利用 Jdk5 的 Annotation 和 Generic 特性, 在 Java Bean 里面标注属性名称对应余数据库表里面的字段名称.
在以及在生成 sql 语句时的匹配方式,比如 like %abc, like %abc%, like abc%, =, <, >...
通过这个Annotation, 把那些 生成 CRUID 的过程独立出来.

用起来好像也蛮方便的.

http://louisling.iteye.com/blog/161398
37 楼 ceip2183 2008-02-04  
深有同感, 我用类似的方法, 做了多个企业级应用, 至今运行良好, ORM框架一个不要, 直接用自己的数据驱动的ceipFrame, 效果和性能一流, 体现:
1). 开发速度快;
2). 运行性能好;
3). 全自主, 多级缓存;
36 楼 maku 2008-02-03  
引用
我只用了Ibatis 40%不到的功能,可能大家会觉得不可思议。我没有用cache,没有用关联,没有用resultMap,甚至,连JavaBean也没有用

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

...

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

在我的项目里大量的使用 resultMap,JavaBean和Map,究竟使用JavaBean还是Map要看具体情况,不能以偏盖全。
eclipse生成JavaBean getter/setter的过程并不痛苦,因为那是工作的一部分;不谈
getter/setter的用处及设计意图,起码他是J2EE规范的一部分,J2EE就是一些约定俗成的规范,你的程序规范,别人阅读和维护起来就容易一些。

感觉楼主似乎厌倦了这些,你可以使用动态语言实现你的想法,但最好别拿java语言开刀。
35 楼 withoutmewang 2008-02-03  
neptune 写道
hashmap用在复杂查询,查询结果比较乱的情况下比较好。但一般情况下最好还是使用pojo好一些.

同意:
查询条件完全使用HashMap,包括排序、分页。
查询结果仍旧使用POJO。

另:不太同意楼主舍弃POJO的观点,就像没写测试代码,让人产生恐慌。
同时,在使用IBATIS的时候,我觉得没必要提到HIBERNATE,这样容易让其他的人偏离话题。
34 楼 leebai 2008-02-03  
基本赞成楼主的观点,OR Maping是典型的穷折腾。
33 楼 sunwei_07 2008-02-03  
我现在喜欢使用JdbcTemplate,外加自己封装的FormBean工具,使用也挺顺手
Ibatis我其实很喜欢,但是由于水平有限,实在不知道很好的怎么解决其中的分页方法
32 楼 Eric_liu 2008-02-02  
仁者见仁,智者见智。若是把握不到hibernate的“脉搏”,还是老实点用ibatis。毕竟上手容易、简单。robbin对这两个orm有篇文章说明
31 楼 Sing 2008-02-02  
是啊,我也准备用ibatis类似的框架,因为这样成本低,hibernate学习起来比ibatis要复杂一些,在优化方面,ibatis和hibernate优化到极致,我估计都差不多,还是要选一个容易上手的比较好.
30 楼 lcllcl987 2008-02-02  
我们公司在产品中也是用到了Ibatis.特别是有复杂表间关系的项目中, Ibatis依赖于早已熟悉的sql经验, 规避了hibernate的复杂性和大多数开发人员对他的不可控性.
如果项目中没有一个hibernate的大牛, 为了项目的可控和将来的维护, 个人还是趋向于Ibatis.

相关推荐

    ibatis自动生成bean

    只需在配置文件ibatorConfig.xml 更改tableName="你的表名"即可自动生成全部。 记住更改jdbc路径和mysql-connector-java-5.1.6-bin.jar的路径。

    ibatis_with_memcached

    本项目"ibatis_with_memcached"就是关于如何将Ibatis与Memcached集成,实现高效的数据库缓存策略的实例。 Ibatis是一个基于Java的SQL映射框架,它允许开发者编写SQL语句并与Java对象进行绑定,从而避免了传统的JDBC...

    基于iBatis SQL Map的数据持久层实现应用研究.pdf

    在本文中,作者以物流系统开发为实例,介绍了基于iBatis SQL Map实现数据持久层的主要内容,这包括映射关系的建立、SQL Map配置文件的编写,以及SQL Map API的使用。 iBatis SQL Map的核心是基于XML配置文件的映射...

    ibatis SQL Map PPt

    **Ibatis SQL Map PPT 知识点详解** Ibatis,作为一个轻量级的Java持久层框架,以其灵活、易用的特点,在企业级应用中得到了广泛的应用。它将SQL语句与Java代码分离,提供了更直观的数据访问方式,极大地提高了开发...

    ibatis的sql-map dtd

    在Ibatis中,`sql-map`和`sql-map-config`是两个重要的XML配置文件,它们使用DTD(Document Type Definition)来定义其结构和规则。 DTD是XML文档类型定义,它定义了XML文档的合法构建块,包括元素、属性、实体等,...

    Spring与iBATIS的集成

    他们也阐明了怎样取得你已编写的SQL语句及把他们映射给iBATIS使用的Bean。最后,还讨论了iBATIS的优缺点,及为什么是这样的一种方式,即所谓的“在完全OR与JDBC之间的一个幽雅的折衷。” &lt;br&gt;就象Developer's ...

    ibatis中iterate的例子

    在iBatis中,`&lt;iterate&gt;`标签是一个非常实用的功能,它允许我们处理集合数据,如数组、List或Map等,进行循环遍历并生成动态SQL语句。下面我们将详细探讨`&lt;iterate&gt;`标签的用法及其示例。 `&lt;iterate&gt;`标签的主要...

    ibatis总结 ibatis ibatis ibatis ibatis

    - `applicationContext.xml`是Spring的主配置文件,它定义了Spring容器中的bean,包括对Struts、Ibatis等其他框架的配置,实现各组件间的依赖注入。 - `codelist.xml`则可能包含了全局共享的bean,如`...

    iBATIS框架源码剖析

    资源名称:iBATIS框架源码剖析内容简介:iBATIS是一种比较流行的ORM框架,本书全面介绍其结构体系和分析其源程序代码,该框架的核心包括两个组件,一个是iBATIS DAO,另一个是iBATIS SQL Map。本书分为三个部分,第...

    ibatis demo,ibatis例子,ibatis示例

    5. **参数映射**:Ibatis支持多种方式传递参数,如Map、POJO对象、注解等。例如,使用`@Param`注解可以指定参数名,或者在XML中使用`#{paramName}`来引用参数。 6. **结果映射**:结果映射允许我们将查询结果自动...

    ibatis电子书

    关于本文 本文讨论了iBATIS SQL Map最重要的特性。本文中没有提及的其他特性,可能以后不再支持或不久将会修改,并且修改时不作通告,因此最好不要使用它们。本文将随着iBatis SQL Map的修改而变更。如

    ibatis plugin用户指南

    1. **代码生成**:基于预设的Bean Template和SQL Map Template,插件可以自动生成Bean和SQL Map文件,大大提高了开发效率。 2. **自动完成**:在sqlMap Config文件中,插件能自动完成properties和sqlMap文件的编写...

    基于iBatis SQL Map的数据持久层实现应用研究 (2008年)

    介绍了iBatis SQL Map建立ORM机制的原理和特点,结合某物流系统的开发,给出了SQL Map建立ORM的主要内容,包括映射关系、SQL Map配置文件和SQL Map API等.实践表明,iBatis SQL Map的ORM实现技术非常方便、灵活,并较好地...

    ibatis源码,ibatis源码 ibatis源码 ibatis源码

    《深入解析iBatis源码》 iBatis,一个优秀的Java持久层框架,以其轻量级、灵活的特性在众多ORM(Object-Relational Mapping)框架中独树一帜。iBatis的核心在于它的SQL映射机制,它将数据库操作与业务逻辑解耦,...

    ibatis2.3.4.rar

    6. 参数映射和结果映射:Ibatis通过Map、POJO(Plain Old Java Object)等方式进行参数映射,将Java对象转换为SQL参数;结果映射则是将查询结果转换为Java对象,方便后续处理。 在实例中,你可以尝试以下几个步骤来...

    Spring MVC Ibatis Bean 根据mysql数据表——代码生成工具

    Spring MVC、Ibatis 和 Bean 是Java Web开发中的关键组件,它们构建了强大的后端架构。在实际项目中,为了提高开发效率,开发者通常会利用代码生成工具,将MySQL数据库中的数据表自动生成对应的Spring MVC ...

    iBATIS-DAO-2.3.4.726.rar_com.ibatis.dao_iBATIS dao 2_iBatis DAO_

    例如,`DynamicSqlMapClient`类支持动态SQL Map的执行,它可以根据传入的参数动态修改SQL语句,避免了大量的条件分支代码。 此外,iBATIS还提供了一些辅助工具,如`ParameterMap`用于管理SQL语句的输入参数,`...

    Spring+ibatis 保留ibatis事务的配置

    配置了JNDI数据源之后,接下来就是配置ibatis的`SqlMapClient` Bean,这个Bean负责读取ibatis的配置文件,建立与ibatis之间的桥梁。 ```xml &lt;bean id="sqlMapClient" class="org.springframework.orm.ibatis....

    iBATIS SQL Maps 开发指南

    SQL Map使用简单的XML配置文件将Java Bean映射成SQL语句,对比其他的数据库持续层和ORM框架(如JDO的实现,Hibernate等),SQL Map最大的优点在于它简单易学。要使用SQL Map,只要熟悉Java Bean,XML和SQL,就能使您...

Global site tag (gtag.js) - Google Analytics