`
happy100583
  • 浏览: 124149 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

最简单的iBatis入门例子

阅读更多

iBatis是一个O/R Mapping解决方案, iBatis最大的特点就是小巧,上手很快。如果你不需要太多复杂的功能,iBatis是能满足你的要求又足够灵活的最简单的解决方案。下面我们看一个最简单的入门例子,是《ibatis 开发指南》上的例子改的,不过上面讲的不仔细,我开始学的时候搞了一个晚上才把那个例子跑起来的,相信一些朋友也和我一样,在入门的时候有一点小郁闷,我把整个工程项目打包了供朋友下载,工具是eclipse3.2+myeclipse5.0,导入即可运行,数据库用的是MySQL。也可以改用别的数据库!

 

先建数据库和表吧;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);

 
 


 

整个工程目录结构如下:

 


lib包下面的文件:


 

下面开始编写每个文件:

 

编写iBatis必须的配置文件SqlMapConfig.xml,放在包com.ctgusec.zhupan.maps下,文件名可以任意改,内容如下:

 

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE sqlMapConfig

    PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"

    "http://www.ibatis.com/dtd/sql-map-config-2.dtd">

<sqlMapConfig>

    <settings cacheModelsEnabled="true" enhancementEnabled="true"

        lazyLoadingEnabled="true" errorTracingEnabled="true" maxRequests="32"

        maxSessions="10" maxTransactions="5" useStatementNamespaces="false" />

 

    <transactionManager type="JDBC">

        <dataSource type="SIMPLE">

            <property name="JDBC.Driver" value="com.mysql.jdbc.Driver" />

           <property name="JDBC.ConnectionURL"    value="jdbc:mysql://localhost/sample" />

           <property name="JDBC.Username" value="root" />

           <property name="JDBC.Password" value="" />

            <property name="Pool.MaximumActiveConnections" value="10" />

            <property name="Pool.MaximumIdleConnections" value="5" />

            <property name="Pool.MaximumCheckoutTime" value="120000" />

            <property name="Pool.TimeToWait" value="500" />

            <property name="Pool.PingQuery" value="select 1 from sample" />

            <property name="Pool.PingEnabled" value="false" />

            <property name="Pool.PingConnectionsOlderThan" value="1" />

            <property name="Pool.PingConnectionsNotUsedFor" value="1" />

        </dataSource>

    </transactionManager>

    <sqlMap resource="com/ctgusec/zhupan/maps/User.xml" />

</sqlMapConfig>
 


 

如果不用mysql数据库,需要重新配置数据源(红色加粗字体标出),更改相应的属性即可。

然后注意到这个配置文件还引用了一个User.xml, iBatis把每个需要O/R Mapping的Java对象关联到一个xml配置文件,我们需要把t_user表映射到一个User类:

package com.ctgusec.zhupan.model;

import java.io.Serializable;

 

public class User implements Serializable {

 

    /**

     * @author zhupan

     */

    private static final long serialVersionUID = 1L;

 

    private Integer id;

 

    private String name;

 

    private Integer sex;

   

    public User() {

    }

 

    public Integer getId() {

        return this.id;

    }

 

    public void setId(Integer id) {

        this.id = id;

    }

 

    public String getName() {

        return this.name;

    }

 

    public void setName(String name) {

        this.name = name;

    }

 

    public Integer getSex() {

        return this.sex;

    }

 

    public void setSex(Integer sex) {

        this.sex = sex;

    }

}
 

 

编写User.xml文件:

<?xml version="1.0" encoding="UTF-8"?>

 

<!DOCTYPE sqlMap

    PUBLIC "-//iBATIS.com//DTD SQL Map 2.0//EN"

    "http://www.ibatis.com/dtd/sql-map-2.dtd">

 

<sqlMap namespace="User">

 

    <typeAlias alias="user" type="com.ctgusec.zhupan.model.User" />

    <select id="getUser" parameterClass="java.lang.String"

        resultClass="user">

        <![CDATA[    select  name,  sex   from t_user   where name = #name#   ]]>

    </select>

   

    <select id="getAllUser" resultClass="user">

        <![CDATA[   select   name,  sex  from t_user  ]]>

    </select>

 

    <update id="updateUser" parameterClass="user">

        <![CDATA[   UPDATE t_user  SET name=#name#, sex=#sex# WHERE id = #id# ]]>

    </update>

 

    <insert id="insertUser" parameterClass="user">

        INSERT INTO t_user ( name, sex) VALUES ( #name#, #sex# )</insert>

 

    <delete id="deleteUser" parameterClass="java.lang.String">

        delete from t_user where id=#value#

    </delete>

</sqlMap>
 

 

通过<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"/>“#name#”在运行期会由传入的user对象的name属性填充。 “#sex#”,将在运行期由传入的 user 对象的sex属性填充。“#id#”,将在运行期由传入的user对象的id属性填充。

 

只要你会写SQL,就能非常容易地写出配置文件。

最后便是如何使用iBatis实现O/R映射,测试给个例子:

package com.ctgusec.zhupan;

 

import java.sql.SQLException;

import java.util.List;

 

import com.ctgusec.zhupan.model.User;

import com.ibatis.sqlmap.client.SqlMapClientBuilder;

 

/**

 *

 * @author zhupan

 */

public class ExampleMain {

 

       public static void update() {

              //首先初始化iBatis获得一个SqlMapClient对象

              String resource = "com/ctgusec/zhupan/maps/SqlMapConfig.xml";

              com.ibatis.sqlmap.client.SqlMapClient sqlMap = null;

              try {

                     java.io.Reader reader = com.ibatis.common.resources.Resources.getResourceAsReader(resource);

                     sqlMap = SqlMapClientBuilder.buildSqlMapClient(reader);

              } catch (Exception e) {

                     e.printStackTrace();

              }

              // sqlMap系统初始化完毕,开始执行update操作

              try {

                     sqlMap.startTransaction();

                     User user = new User();

                     user.setId(new Integer(1));

                     user.setName("zhupan");

                     user.setSex(new Integer(1));

                     sqlMap.update("updateUser", user);

                     sqlMap.commitTransaction();

              } catch (SQLException e) {

                     System.out.println(e.getMessage());

              } finally {

                     try {

                            sqlMap.endTransaction();

                     } catch (SQLException e) {

                            e.printStackTrace();

                     }

              }

       }

       public static List getUser() {

//            首先初始化iBatis获得一个SqlMapClient对象

              String resource = "com/ctgusec/zhupan/maps/SqlMapConfig.xml";

              com.ibatis.sqlmap.client.SqlMapClient sqlMap = null;

              List user=null;

              try {

                     java.io.Reader reader = com.ibatis.common.resources.Resources.getResourceAsReader(resource);

                     sqlMap = SqlMapClientBuilder.buildSqlMapClient(reader);

              } catch (Exception e) {

                     e.printStackTrace();

              }

              // sqlMap系统初始化完毕,开始执行getAllUser操作

              try {

                     sqlMap.startTransaction();                        

                     user=sqlMap.queryForList("getAllUser", null);

                     sqlMap.commitTransaction();

              } catch (SQLException e) {

                     System.out.println(e.getMessage());

              } finally {

                     try {

                            sqlMap.endTransaction();

                     } catch (SQLException e) {

                            e.printStackTrace();

                     }

              }

              return user;

       }

       public static void main(String[] args) {

              update();

              List user=getUser();      

              for(int i=0;i<user.size();i++)

              {

                     System.out.println(((User)user.get(i)).getName());

              }

       }

}
 

 

 


运行时把lib包下的所有.jar构建到路径中,操作如下:

 

点击    找到.jar文件全部选中,确认即可

总结:iBatis确实简单灵活,上手容易,代码很少,配置稍嫌复杂。动态SQL的确是个强点,熟悉后感觉很不错。iBatis中所有的DAO方法都只传一个值对象,复杂查询当然也不例外。另外对常见的1:1,1:N关系的支持不如Hibernate。使用iBatis 2.0和1.0有较大区别,主要体现在配置文件上,iBatis 2.0新增了DAO框架,不需要Spring提供的DAO也能很方便地实现DAO模式。持久层使用了iBatis后,团队中以前乱七八糟的jdbc包装不见了,大家的编码风格统一了,可以集中精力进行业务组件的编写!

分享到:
评论

相关推荐

    最简单的iBatis入门例子.rar

    这个“最简单的iBatis入门例子.rar”压缩包文件显然是为了帮助初学者快速理解和上手iBatis。 在学习iBatis之前,首先需要理解什么是持久层框架。持久层是应用程序中负责数据存储的部分,它处理与数据库的交互。...

    iBatis简单入门实例(以Oracle为例)

    iBatis 简介: iBatis 是apache 的一个开源项目,一个O/R Mapping 解决方案,iBatis 最大的特点...如果不需要太多复杂的功能,iBatis 是能够满足你的要求又足够灵活的最简单的解决方案,这是一个ibtis的增删改查例子。

    Ibatis(中文文档,还有一个调好的例子)

    下面我们看一个最简单的入门例子,是《ibatis 开发指南》上的例子改的,不过上面讲的不仔细,我开始学的时候搞了一个晚上才把那个例子跑起来的,相信一些朋友也和我一样,在入门的时候有一点小郁闷,我把整个工程...

    ibatis简单例子

    在我们的简单例子中,我们先来看`最简单的iBatis入门例子.chm`,这个CHM文件通常包含详细的教程或文档。里面可能详细介绍了如何创建一个基本的iBATIS项目,包括如何设置项目结构、创建数据库表、编写SQL映射文件、...

    关于Ibatis的jar包

    在提供的压缩包中,有两个关键文件:`最简单的iBatis入门例子.chm`和`Ibatis包`。让我们一一解析它们: 1. **最简单的iBatis入门例子.chm**: 这是一个帮助文件,通常包含一系列关于如何快速入门Ibatis的教程和...

    IBatis入门教程

    接下来,我们以一个简单的例子——Student类——来了解如何在iBatis中进行操作: ```java // Student.java public class Student { private int id; private String name; private Date birth; private float ...

    ibatis

    在给定的压缩包文件中,我们可以看到两个资源:一个是最简单的iBatis入门例子.chm,这可能是一个帮助文档,详细解释了如何开始使用iBatis;另一个是ibatisJavaTest,这可能是一个包含示例代码的Java测试项目。 首先...

    iBatis 例子(推荐学习)

    让我们来看一下最简单的iBatis入门例子。在例子中,我们通常会有一个`SqlMapConfig.xml`配置文件,用于设置数据源、事务管理器等信息。接着,创建一个`UserMapper.xml`文件,定义SQL映射,比如查询用户信息的SQL: ...

    iBatisrumen.rar_ibatis

    首先,`最简单的iBatis入门例子.chm`很可能是一个帮助文档,它会引导初学者逐步了解如何搭建iBatis环境,创建第一个简单的数据访问示例。在iBatis中,我们通常需要配置SqlMapConfig.xml文件,这是整个iBatis系统的主...

    ibatis学习锦集

    IBATIS最新最全开发指南 - 通俗易懂IBATIS教程,ibatis基础,ibatis入门.JpetStore_4等!",这说明这份资源不仅全面,还强调了易理解性,特别提到了iBatis的基础知识和入门教程,以及JpetStore_4项目,这是一个经典...

    iBATIS 2.0 开发指南

    - **简单性**:iBATIS 的 API 相对简单,学习曲线较平缓,适合希望快速上手的开发者。 - **轻量级**:相比其他 ORM 框架,iBATIS 更加轻量级,资源占用少,对于资源敏感的应用程序来说是个很好的选择。 #### 快速...

    ibatis 开发指南,开发手册 txt 版

    ### iBatis 开发指南与手册知识点概览 #### iBatis简介 iBatis是一个开源框架,用于处理数据库操作,特别...通过阅读官方文档和实践操作,开发者能够深入了解iBatis的核心功能,并根据项目需求选择最适合的技术方案。

    IBATIS实例代码

    【描述】中提到“IBATIS实例入门代码,数据库使用MYSQL”,这意味着我们将探讨如何使用IBATIS与MySQL数据库配合进行开发。MySQL是一种广泛使用的开源关系型数据库管理系统,具有高效、稳定和易用的特点,是许多Java...

Global site tag (gtag.js) - Google Analytics