介绍
iBATIS是以SQL为中心的持久化层框架。能支持懒加载、关联查询、继承等特性。
iBATIS不同于一般的OR映射框架。OR映射框架,将数据库表、字段等映射到类、属性,那是一种元数据(meta-data)映射。iBATIS则是将SQL查询的参数和结果集映射到类。
所以,iBATIS做的是SQL Mapping的工作。
它把SQL语句看成输入以及输出,结果集就是输出,而where后面的条件参数则是输入。iBATIS能将输入的普通POJO对象、Map、XML等映射到SQL的条件参数上,同时也可以将查询结果映射到普通POJO对象(集合)、Map、XML等上面。
iBATIS使用xml文件来映射这些输入以及输出。
简单示例
基于ibatis-2.3.0.677版本。
1、 创建新的项目,并引入jar包
a) ibatis-2.3.0.677.jar
b) mysql驱动
2、 在类路径中提供ibatis的配置文件:sqlMapConfig.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE sqlMapConfig
PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN"
"http://ibatis.apache.org/dtd/sql-map-config-2.dtd">
<sqlMapConfig>
<transactionManager type="JDBC" commitRequired="false">
<dataSource type="SIMPLE">
<property name="JDBC.Driver" value="com.mysql.jdbc.Driver"/>
<property name="JDBC.ConnectionURL" value="jdbc:mysql://127.0.0.1/crm"/>
<property name="JDBC.Username" value="root"/>
<property name="JDBC.Password" value="mysql"/>
</dataSource>
</transactionManager>
<sqlMap resource="com/ysen/model/User.xml"/>
3、创建实体类:User.java
public class User {
private int id;
private String username;
private String password;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
}
4、创建针对User对象的CRUD的xml映射配置:User.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE sqlMap
PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"
"http://ibatis.apache.org/dtd/sql-map-2.dtd">
<sqlMap>
<!-- Use type aliases to avoid typing the full classname every time. -->
<typeAlias alias="User" type="com.ysen.model.User"/>
<!-- Select with no parameters using the result map for Account class. -->
<select id="selectAllUsers" resultClass="User">
select * from t_user
</select>
<select id="selectUser" resultClass="User" parameterClass="int">
select * from t_user where id=#id#
</select>
<insert id="insertUser" parameterClass="User">
insert into t_user values (
null,#username#,#password#
)
</insert>
<update id="updateUser" parameterClass="User">
update t_user set username = #username#,password=#password#
where id=#id#
</update>
<delete id="deleteUser" parameterClass="int">
delete from t_user where id=#id#
</delete>
</sqlMap>
5、创建测试程序测试:
import java.io.Reader;
import java.util.Iterator;
import java.util.List;
import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;
/**
* 最简单的形式!
* @author Lee
*
*/
public class UserTest {
/**
* @param args
*/
public static void main(String[] args) throws Exception{
//从配置文件中得到SqlMapClient对象
Reader reader = Resources.getResourceAsReader("sqlMapConfig.xml");
SqlMapClient sqlMapper = SqlMapClientBuilder.buildSqlMapClient(reader);
reader.close();
//创建用户数据
for(int i=0; i<10; i++){
User user = new User();
user.setUsername("用户"+i);
user.setPassword("密码"+i);
sqlMapper.insert("insertUser", user);
}
//查询用户数据
List users = sqlMapper.queryForList("selectAllUsers");
for (Iterator iter = users.iterator(); iter.hasNext();) {
User user = (User) iter.next();
System.out.println(user.getUsername());
}
//查询特定用户的数据
User user = (User)sqlMapper.queryForObject("selectUser", 1);
System.out.println("用户【id="+1+"】的名称是:"+user.getUsername());
//更新用户的信息
user = new User();
user.setId(3);
user.setUsername("更改之后的用户名称");
user.setPassword("密码被更改");
sqlMapper.update("updateUser", user);
//删除用户的信息
sqlMapper.delete("deleteUser", 6);
}
分享到:
相关推荐
【标题】"01_传智播客ibatis教程_准备ibatis环境"涉及的是一个关于集成和配置Java持久层框架iBatis的学习资源,由传智播客提供,由赖老师主讲。这个教程主要目标是帮助开发者搭建并熟悉iBatis的开发环境,以便后续...
2. **Ibatis框架介绍**:理解Ibatis的基本概念,它是一个基于Java的持久层框架,通过XML或注解来映射SQL语句,实现了SQL与Java代码的分离。 3. **Ibatis下载与引入**:从官方网站或者Maven仓库下载Ibatis的jar包,...
这个压缩包可能包含了介绍、教程、示例代码或者测试用例,帮助用户理解和学习Ibatis的使用。 描述中的"一个很好的例子"提示我们,这个压缩包包含的内容可能是Ibatis的实际应用展示,可能是通过一个具体的项目或案例...
这篇“ibatis学习笔记(一)”可能是博主对Ibatis基础概念、安装配置以及基本使用的介绍,让我们通过标签“源码”和“工具”来深入探讨Ibatis的相关知识。 首先,Ibatis是一个轻量级的Java ORM(对象关系映射)框架...
本文将详细介绍如何使用Spring框架、iBatis(现称为MyBatis)和JOTM来实现Java Transaction API (JTA)的分布式事务处理。 #### 二、基础知识简介 **1. Spring框架** - **概述**:Spring是一个开源的轻量级Java...
MyBatis的前身就是iBatis , MyBatis使用XML描述符或注释将对象与存储过程或SQL语句耦合,将关系数据库与面向对象应用程序结合使用变得更加容易。支持定制化SQL、存储过程以及高级映射。
本教程将详细介绍如何将Spring Boot与iBatis以及MySQL数据库进行整合,为你的Web应用构建强大的数据处理能力。 首先,我们需要理解Spring Boot的核心特性。Spring Boot通过“约定优于配置”的原则,使得开发者能够...
第二章介绍了Hibernate,这是一个流行的ORM(Object-Relational Mapping)框架,它消除了直接使用JDBC的许多麻烦。通过Hibernate,开发者可以使用面向对象的方式来操作数据库,无需关心底层的SQL语法。优点是简化了...
《Spring+SpringMVC+MyBatis+SpringBoot视频01》是一套全面介绍Java开发中常用技术框架的教程,涵盖了Spring、SpringMVC、MyBatis和SpringBoot的核心概念和实战应用。以下是对这些标签及文件内容的详细解读: 1. **...
Java面试题01.面试的整体流程 Java面试题02.java的垮平台原理 Java面试题03.搭建一个java的开发环境 Java面试题04.java中int占几个字节 Java面试题05.java面向对象的特征 Java面试题06.装箱和拆箱 Java面试题07.==和...
- **核心组件**:使用EJB进行业务逻辑处理、Ibatis作为数据访问对象。 - **问题**:虽然性能有所提升,但仍存在开发效率低下、成本过高等问题。 ##### V2.1 (2004.10-2007.01) - **架构优化**:从WebLogic切换到...
接下来,我们将详细介绍Spring 2.5至3.0版本中包含的关键Jar包及其功能: 1. **spring-core.jar** 这个Jar包包含了Spring框架的基础部分,是所有Spring应用的基础,提供了IoC容器的基础实现。它还包含了核心工具...
5 CSS01讲义 6 servle技术初步入门 7 servle核心技术 8 JSP技术初步入门 9 JSP核心技术与应用 10 JSTL技术介绍 11 MVC框架技术实现 13 struts框架 14 持久层设计技术hibernate 15 spring框架 专题 信息分页 专题 ...
- **MyBatis** 是 Apache 软件基金会下的一个开源项目,前身是 iBatis 框架。2010 年从 Apache 迁移到 Google Code 下,并更名为 MyBatis,后于 2013 年迁移到 GitHub ...
这个压缩包包含了一系列文档,详细介绍了不同主题,让我们逐一解析其中的重要知识点。 首先,我们看到关于IBM WebSphere的内容,这是一款强大的应用服务器,广泛用于企业级应用部署。"通向架构师的道路(第十五天)...
java面试题01.面试的整体流程.mp4 │ Java面试题02.java的垮平台原理.mp4 │ Java面试题03.搭建一个java的开发环境.mp4 │ Java面试题04.java中int占几个字节.mp4 │ Java面试题05.java面向对象的特征.mp4 │ Java...
本文将详细介绍如何在MyBatis-Plus中配置控制台打印这样的SQL。 首先,问题背景是开发人员在编写SQL语句时,通常需要结合控制台输出和数据库管理工具(如Navicat或PLSQL)来检查和验证SQL的正确性。如果只看到占位...
通过以上知识点的介绍,可以看出Sun官方及国内外技术社区为Java学习者提供了非常全面且实用的学习资源,涵盖了从基础概念到高级技术的应用。无论是初学者还是有经验的开发者,都可以从中找到适合自己水平的内容,...
MyBatis 使用简单的 XML 或注解进行配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 对象)映射成数据库中的记录。 MyBatis 最初是由 Apache 的一个开源项目 iBatis 发展而来的,在 ...