- 浏览: 615513 次
- 性别:
- 来自: 厦门
文章分类
最新评论
-
咖啡舞者:
现在在厦门工作还好吧。
2013换工作记 -
huih1984:
工作8年,算起来楼主和我差不多岁数啊, ,本人现在干着没有合同 ...
2013换工作记 -
无心流泪wan:
乘法法则规定复数的乘法按照以下的法则进行:设z1=a+bi,z ...
帮朋友做的一笔试(友元 运算符重载) -
我叫营长1:
谢谢,很详细呢
SharedPreferences 的用法 -
javalinjx:
挺有意思的。哈哈
2013换工作记
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>
下面开始编写每个文件: <o:p> </o:p>
编写
iBatis
必须的配置文件
SqlMapConfig.xml
,放在包
com.ctgusec.zhupan.maps
下,文件名可以任意改,内容如下:
- <!-- -->xml version = "1.0" encoding = "UTF-8" ?>
- <!-- -->
- 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
类:
<o:p></o:p>
- 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
文件:
<o:p></o:p>
- <!-- -->xml version = "1.0" encoding = "UTF-8" ?>
- <!-- -->
- 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" >
- <!-- -->
- select
- name,
- sex
- from t_user
- where name = #name#
- ]]>
- select >
- < select id = "getAllUser" resultClass = "user" >
- <!-- -->
- select
- name,
- sex
- from t_user where name = #name#
- ]]>
- select >
- < update id = "updateUser" parameterClass = "user" >
- <!-- -->
- 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"></typealias> “ #name# ”在运行期会由传入的 user 对象的 name 属性填充。 “ #sex# ”,将在运行期由传入的 user 对象的 sex 属性填充。“ #id# ”,将在运行期由传入的 user 对象的 id 属性填充。 <o:p></o:p> <o:p> </o:p>
只要你会写
SQL
,就能非常容易地写出配置文件。
最后便是如何使用
iBatis
实现
O/R
映射
,
测试给个例子:
运行时把
lib
包下的所有
.jar
构建到路径中,操作如下:
- 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
- {
- System.out.println(((User)user.get(i)).getName());
- }
- }
- }
总 结: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 开发指南》会更容易明白!
发表评论
-
java中使用存储过程出现"该语句没有返回结果集"
2012-02-14 15:32 1919在jsp中调用存储过程,本来用的是sqlserver200 ... -
智能校车---校车解决方案
2012-01-30 13:37 1442... -
一个澳大利亚大三学生的作业
2010-12-06 15:33 1526最近有一个澳大利亚的学生来公司做二个月的实生,听他说是这他们学 ... -
WebLogic部署数据源
2010-10-22 08:47 2097http://www.cstc.org.cn/tabid/88 ... -
javax.net.ssl.SSLHandshakeException
2010-07-28 11:09 14441在执行webservice的过程中,出现如下异常: ja ... -
j2me 在手机上,截屏你的程序
2010-07-12 15:16 1378收藏起来:http://www.iteye.com/topic ... -
LWUIT显示漂亮的loading界面的两种方法
2010-07-06 20:23 2783强烈推荐此blog作者的博客 原文出处:http:// ... -
轻量级用户界面工具包(LWUIT)简介
2010-06-02 16:10 1764原文出处:http://developer ... -
LWUIT的资源编辑与应用
2010-06-02 16:06 1728在LWUIT下载包中,有一个名为“Resource Edi ... -
LWUIT的布局与Style的使用
2010-06-02 16:04 1702一、LWUIT的布局 LWUIT一共有五个布局,分别是: ... -
关于WAP项目有话要说
2010-05-27 16:05 1807搞一了个月的 ... -
WAP相关资料
2010-05-07 08:48 1599在上次视频中,演示了安装 jdk 1.7 和 Nokia Mo ... -
linux安装svn 分享
2010-03-30 10:46 2119在linux下安装配置svn独立服务器 SVN技术网 www ... -
解决Mysql无法远程连接的问题
2010-03-29 14:18 3840解决Mysql 无法远程 ... -
svn eclipse插件突然失效怎么办?
2010-03-26 14:24 7118前段时间遇到了svn eclipse插件突然失效的问题,差 ... -
实战篇:设计自己的Annotation
2010-03-23 13:36 750Annotation在java的世界正铺天盖地展开,有空 ... -
tomcat:java.lang.outofmemoryerror permgen space
2010-03-04 15:55 1118这个问题是我的工程中 ... -
如struts中配有如下几个action,ManagerUserAction中有与之对应的方法 <action name="addUser" class="
2010-03-04 11:16 2966如struts中配有如下几个action,ManagerUse ... -
Spring2.5注释驱动与基于注释的MVC
2010-03-03 15:35 1214转摘自:http://tonyaction.blog.51ct ... -
log4j:WARN Please initialize the log4j system properly 问题解决
2010-03-03 11:06 4354今天花了点时间搞定了个并不是很重要的问题 在tomcat ...
相关推荐
在本教程中,我们将通过一个简单的Ibatis入门例子,带你逐步了解并掌握这个强大的框架。 首先,我们需要在项目中引入Ibatis的依赖。通常,我们会在Maven的pom.xml文件中添加以下依赖: ```xml <groupId>org....
《Ibatis 入门经典 实例》 Ibatis 是一款著名的轻量级 Java 持久层框架,它提供了一种映射 SQL 和 Java 对象的简单方式,从而减轻了开发人员在数据库操作中的工作负担。这篇实例教程将带你深入理解 Ibatis 的核心...
在这个"ibatis入门实例(全代码)"中,我们将探讨如何通过 Ibatis 实现对数据库的操作,包括数据库的初始化、SQL 映射文件的编写以及 Java 代码的集成。 首先,让我们了解数据库的准备工作。在实例中,提供了数据库...
在这个“iBatis入门实例详细代码”中,我们将深入探讨如何使用iBatis与MySQL数据库进行交互。 首先,我们需要在MySQL数据库中创建相应的表。这个实例可能涉及一个简单的表结构,如用户表(users),包含字段如id...
这个“最简单的iBatis入门例子”提供了CHM格式的教程,非常适合Java初学者快速入门。 1. **iBatis简介** - iBatis是MyBatis的前身,它是一个基于Java的持久层框架,处理SQL映射和数据访问。 - iBatis的核心是XML...
**iBATIS入门实例测试** iBATIS是一个优秀的开源持久层框架,它简化了Java应用程序与数据库之间的交互,使得开发者可以专注于SQL语句本身,而无需处理大量的JDBC代码。本教程将通过一个简单的实例来介绍如何使用...
**Ibatis 入门实例详解** Ibatis 是一个优秀的、开源的 Java 数据访问框架,它简化了数据库操作,使得开发者可以更加专注于 SQL 而不需处理底层的 JDBC 编码。Ibatis 提供了一个映射框架,允许将 SQL 查询与 Java ...
这个“iBatis 入门例子”提供了完整的源代码,帮助初学者快速理解和掌握iBatis的核心概念和使用方法。 首先,让我们了解iBatis的基本架构。iBatis的核心组成部分包括配置文件、SQL映射文件和DAO接口。配置文件...
这个“最简单的iBatis入门例子.rar”压缩包文件显然是为了帮助初学者快速理解和上手iBatis。 在学习iBatis之前,首先需要理解什么是持久层框架。持久层是应用程序中负责数据存储的部分,它处理与数据库的交互。...
【标题】:“ibatis入门实例” Ibatis,全称MyBatis,是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。Ibatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。Ibatis可以被看作是一个半...
在"ibatis入门例子"中,我们可以学习到以下关键知识点: 1. **安装与配置**:首先,我们需要下载Ibatis的jar包,并将其添加到项目的类路径中。接着,配置Ibatis的核心配置文件`mybatis-config.xml`,在这个文件中,...
**Ibatis 入门例子详解** Ibatis 是一款优秀的、轻量级的Java持久层框架,它主要解决了Java应用程序与数据库交互的问题。本教程将通过一个基础的Ibatis入门示例,帮助你理解如何在实际项目中使用Ibatis进行数据操作...
以上就是iBATIS入门的基础内容,通过实践这个简单的例子,你可以了解如何在Java应用中集成iBATIS进行数据库操作。在实际开发中,还可以利用iBATIS的动态SQL、结果映射等功能,进一步提升代码的可读性和可维护性。