简介:
jar包
普通的javaBean: domain.User
与bean对应的SQL映射文件: maps/User.xml
iBatis需要的配置文件: SqlMapConfig.xml
加载iBatis配置文件SqlMapConfig.xml是相对于class loader所在目录的相对路径. 如在Web程序中,例如Tomcat下时,class loader所对应的目录是WEB-INF/classes目录. 如在普通的单机运用程序中,class loader对应的目录是编译生成class的bin目录(把src和bin分开存放时).
1. 需要的jar包(暂且先用下面的,可到http://www.javaeye.com/topic/26433示例中一起下载):
commons-dbcp.jar,commons-logging-api.jar, commons-logging.jar, commons-pool.jar,
hsqldb.jar, ibatis-common-2.jar, ibatis-dao-2.jar, ibatis-sqlmap-2.jar,
mysql-connector-java-3.1.12-bin.jar
2. 类User:
package domain;
public class User {
private int id;
private String name;
public User() {}
public User(String name) { this(0, name); }
public User(int id, String name) {
this.id = id;
this.name = name;
}
public int getId() { return id; }
public void setId(int id) { this.id = id; }
public String getName() { return name; }
public void setName(String name) { this.name = name; }
@Override
public String toString() { return "ID: " + id + ", Name: " + name; }
}
3. 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="domain.User" />
<typeAlias alias="string" type="java.lang.String" />
<typeAlias alias="integer" type="java.lang.Integer" />
<!-- 增删查改的Statement配置 -->
<select id="getAllUsers" resultClass="user"><![CDATA[
SELECT id, name FROM user ORDER BY id
]]></select>
<select id="getUser" resultClass="user" parameterClass="integer"><![CDATA[
SELECT id, name FROM user WHERE id=#id#
]]></select>
<update id="updateUser" parameterClass="user"><![CDATA[
UPDATE user SET name=#name# WHERE id=#id#
]]></update>
<insert id="insertUser" parameterClass="user"><![CDATA[
INSERT INTO user (name) VALUES (#name#)
]]></insert>
<delete id="deleteUser" parameterClass="integer"><![CDATA[
DELETE FROM user WHERE id=#id#
]]></delete>
</sqlMap>
4. iBatis需要的配置文件:
<?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">
<!-- JDBC连接需要的配置 -->
<property name="JDBC.Driver" value="com.mysql.jdbc.Driver" />
<property name="JDBC.ConnectionURL"
value="jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8" />
<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="maps/User.xml" />
</sqlMapConfig>
5. 使用iBatis访问数据库:
package test;
import java.io.IOException;
import java.io.Reader;
import java.util.List;
import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;
import domain.User;
public class Test {
public static enum Mode {
INSERT, UPDATE, DELETE
}
public void update(Object arg, Mode mode) {
SqlMapClient smc = null;
try {
smc = getSqlMapClient();
smc.startTransaction();
switch (mode) {
case INSERT: smc.insert("insertUser", arg); break;
case UPDATE: smc.update("updateUser", arg); break;
case DELETE: smc.delete("deleteUser", arg); break;
}
smc.commitTransaction();
} catch (Exception e) {
e.printStackTrace();
} finally {
endTransaction(smc);
}
}
public void listUsers() {
SqlMapClient smc = null;
try {
smc = getSqlMapClient();
smc.startTransaction();
List users = smc.queryForList("getAllUsers", null);
System.out.println(users);
smc.commitTransaction();
} catch (Exception e) {
e.printStackTrace();
} finally {
endTransaction(smc);
}
}
public User selectUser(int id) {
User user = null;
SqlMapClient smc = null;
try {
smc = getSqlMapClient();
smc.startTransaction();
user = (User) smc.queryForObject("getUser", id);
smc.commitTransaction();
} catch (Exception e) {
e.printStackTrace();
} finally {
endTransaction(smc);
}
return user;
}
// ////////////////////////////////////////////////////////////////////////
// Don't care
// ////////////////////////////////////////////////////////////////////////
private SqlMapClient getSqlMapClient() throws IOException {
// 初始化ibatis, 获得一个SqlMapClient对象
String resource = "SqlMapConfig.xml";
Reader reader = Resources.getResourceAsReader(resource);
return SqlMapClientBuilder.buildSqlMapClient(reader);
}
private void endTransaction(SqlMapClient smc) {
if (smc == null) { return; }
try {
smc.endTransaction();
} catch (Exception e2) {
e2.printStackTrace();
}
}
public static void main(String[] args) {
Test t = new Test();
t.listUsers();
User user = new User("Biao");
user = t.selectUser(7);
user.setName("Biao 黄河");
t.update(user, Mode.UPDATE);
// t.update(user, Mode.INSERT);
// t.update(Integer.valueOf(7), Mode.DELETE);
t.listUsers();
}
}
分享到:
相关推荐
很简单的iBatis入门例子,很简单,CHM格式的。适合JAVA初学者
自己写了一个Ibatis入门文件 JDK用的1.4 ibatis用的2.3.0 一定要注意版本问题,不然出现本本不兼容很费劲,我调了一上午,注意一定要用JDK1.4 ibatis2.3.0! 数据库自己建一张简单的表就行了,特别说明 只适合新手...
持久层框架ibatis:讲解ibatis入门与核心技术,分别实现mysql、oracle、sql server数据库的信息系统开发。 表现层框架struts 1:讲解struts 1的入门配置、核心组件、标签库、国际化、数据校验、sitemesh集成、...
ibatis入门级完整示例,包含ibatis-2.3.4.726.jar、commons-logging-1.0.4.jar、mysql-connector-java-3.1.10-bin.jar和建表语句。
持久层框架iBATIS:讲解iBATIS入门与核心技术,分别实现MySQL、Oracle、SQL Server数据库的信息系统开发。表现层框架Struts 1:讲解Struts 1的入门配置、核心组件、标签库、国际化、数据校验、Sitemesh集成、数据库...
持久层框架ibatis:讲解ibatis入门与核心技术,分别实现mysql、oracle、sql server数据库的信息系统开发。 表现层框架struts 1:讲解struts 1的入门配置、核心组件、标签库、国际化、数据校验、sitemesh集成、...
持久层框架ibatis:讲解ibatis入门与核心技术,分别实现mysql、oracle、sql server数据库的信息系统开发。 表现层框架struts 1:讲解struts 1的入门配置、核心组件、标签库、国际化、数据校验、sitemesh集成、...
Java - SpringMVC+iBatis maven工程项目增删改查实例入门+源码
java主流框架IBATIS,这个教程很全,适合入门。
ibatis入门教程,即学即会,简单上手;
持久层框架hibernate:...持久层框架ibatis:讲解ibatis入门与核心技术,分别实现MySQL,oracle、SQLserver数据库的信息系统开发 表现层struts1 :讲解struts1 的入门配置,核心组件,标签库,国际化,数据校验 等等
java 学生成绩管理源码,简单的半成品,供学习基础入门用,框剪:ibatis
ibatIS是java与数据库连接 非常好的实现了OO思想,是对数据库的操作变得更加简单
ibatis入门实例,推荐配合博客使用http://blog.csdn.net/lg930503/article/details/50463249
java iBATIS-SqlMaps-2-快速入门教程
传智播客ibatis视频教程,共9课,教你如何使用ibatis,有视频、教案、sql脚本,永久链接,欢迎下载!
使用IBATIS 2.3.0677包,SQL SERVER 2005作为数据库,MYECLIPSE 8.5编写
本文档是《Java Web开发教程——入门与提高篇(JSP+Servlet)》一书的附赠电子资料,对Struts2、JSF、Hibernate、iBATIS和JPA等框架进行了简单介绍,并且给出了两个自定义简单框架,还包括3个实例,共149页。
附录A iBATIS.NET快速入门 264 A.1 比较iBATIS和iBATIS.NET 264 A.1.1 为何Java开发人员应该关心iBATIS.NET 264 A.1.2 为何.NET开发人员应该关心iBATIS.NET 265 A.1.3 主要区别是什么 265 A.1.4 相似之处又在哪里 ...
ibatis资料整理.zip ibatis 整理 zip 入门 java 个人学习收集网上资料辛苦整理而成 制作chm老是报错,只好压缩上传了。