锁定老帖子 主题:iBatis入门例子
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2006-10-08
iBatis 是一个 O/R Mapping 解决方案, iBatis 最大的特点就是小巧,上手很快。如果你不需要太多复杂的功能, iBatis 是能满足你的要求又足够灵活的最简单的解决方案。下面我们看一个最简单的入门例子,是《 ibatis 开发指南》上的例子改的,不过上面讲的不仔细,我开始学的时候搞了一个晚上才把那个例子跑起来的,相信一些朋友也和我一样,在入门的时候有一点小郁闷,我把整个工程项目打包了供朋友 下载 ,工具是 eclipse3.2+myeclipse5.0 ,导入即可运行,数据库用的是 MySQL 。也可以改用别的数据库!<o:p></o:p> <o:p> </o:p> 先建数据库和表吧; sql 语句我导出来了: /**/ /* SQLyog 企业版 - MySQL GUI v4.1 主机 - 5.0.7-beta-nt : 数据库 - sample ********************************************************************* 服务器版本 : 5.0.7-beta-nt create database if not exists `sample`; USE `sample`; /* 数据表 `t_user` 的表结构 */ drop table if exists `t_user`; CREATE TABLE `t_user` ( `id` int ( 11 ) NOT NULL auto_increment, ` name ` varchar ( 50 ) default NULL , `sex` int ( 11 ) default NULL , PRIMARY KEY (`id`) ) ENGINE = InnoDB DEFAULT CHARSET = latin1; /**/ /* 数据表 `t_user` 的数据 */ insert into `t_user` values ( 1 , ' zhupan ' , 1 ),( 2 , ' zhupan ' , 2 ),( 3 , ' 3 ' , 3 ),( 4 , ' 4 ' , 4 ),( 5 , ' 5 ' , 5 ); 下面开始编写每个文件: <o:p> </o:p> 编写 iBatis 必须的配置文件 SqlMapConfig.xml ,放在包 com.ctgusec.zhupan.maps 下,文件名可以任意改,内容如下: xml 代码
如果不用 mysql 数据库,需要重新配置数据源,更改相应的属性即可。
java 代码
xml 代码
通过insert、delete、update、select节点,分别定义了针对 TUser 对象的增删改查操作。在这些节点中,我们指定了对应的 SQL 语句:ID 指定了操作 ID,之后我们可以在代码中通过指定操作 id 来执行此节点所定义的操作,如: sqlMap.update("updateUser",user); ID设定使得在一个配置文件中定义两个同名节点成为可能(两个update节点,以不同id区分) parameterClass 指定 了 操 作 所 需的 参 数 类型 , 此例 中 update 操 作 以com.ctgusec.zhupan.model.User 类型的对象作为参数,目标是将提供的 User实例更新到数据库。 parameterClass="user"中,user为“com.ctgusec.zhupan.model.User”类的别名,别名可通过typeAlias节点指定,如示例配置文件中的:<typealias alias="user" type="com.ctgusec.zhupan.model.User"></typealias>“#name#”在运行期会由传入的user对象的name属性填充。 “#sex#”,将在运行期由传入的 user 对象的sex属性填充。“#id#”,将在运行期由传入的user对象的id属性填充。<o:p></o:p> <o:p> </o:p> 只要你会写SQL,就能非常容易地写出配置文件。 java 代码
总结:iBatis确实简单灵活,上手容易,代码很少,配置稍嫌复杂。动态SQL的确是个强点,熟悉后感觉很不错。iBatis中所有的DAO方法都只传一个值对象,复杂查询当然也不例外。另外对常见的1:1,1:N关系的支持不如Hibernate。使用iBatis 2.0和1.0有较大区别,主要体现在配置文件上,iBatis 2.0新增了DAO框架,不需要Spring提供的DAO也能很方便地实现DAO模式。持久层使用了iBatis后,团队中以前乱七八糟的jdbc包装不见了,大家的编码风格统一了,可以集中精力进行业务组件的编写! 源文件下载见附件 Ps :结合《 ibatis 开发指南》会更容易明白! 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2007-02-22
<p>发张图片上来,好象上面帖子中的图片需要登陆后才能显示</p>
|
|
返回顶楼 | |
发表时间:2007-02-22
不过还得说下..
你写的ibates入门挺好的 |
|
返回顶楼 | |
发表时间:2007-05-09
|
|
返回顶楼 | |
发表时间:2007-08-03
getUser()为什么取不出值来...增,删,改没问题!
还是感谢楼主..今天第一次玩这个 ! |
|
返回顶楼 | |
浏览 35684 次