`
ysen
  • 浏览: 122188 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

ibatis使用介绍01

阅读更多

介绍

iBATIS是以SQL为中心的持久化层框架。能支持懒加载、关联查询、继承等特性。

iBATIS不同于一般的OR映射框架。OR映射框架,将数据库表、字段等映射到类、属性,那是一种元数据(meta-data)映射。iBATIS则是将SQL查询的参数和结果集映射到类。

 

所以,iBATIS做的是SQL Mapping的工作。

 

它把SQL语句看成输入以及输出,结果集就是输出,而where后面的条件参数则是输入。iBATIS能将输入的普通POJO对象、MapXML等映射到SQL的条件参数上,同时也可以将查询结果映射到普通POJO对象(集合)、MapXML等上面。

 

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对象的CRUDxml映射配置: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);
	}

 

0
0
分享到:
评论

相关推荐

    01_传智播客ibatis教程_准备ibatis环境

    【标题】"01_传智播客ibatis教程_准备ibatis环境"涉及的是一个关于集成和配置Java持久层框架iBatis的学习资源,由传智播客提供,由赖老师主讲。这个教程主要目标是帮助开发者搭建并熟悉iBatis的开发环境,以便后续...

    01_ibatis教程_准备ibatis环境.zip

    2. **Ibatis框架介绍**:理解Ibatis的基本概念,它是一个基于Java的持久层框架,通过XML或注解来映射SQL语句,实现了SQL与Java代码的分离。 3. **Ibatis下载与引入**:从官方网站或者Maven仓库下载Ibatis的jar包,...

    ibatis.zip

    这个压缩包可能包含了介绍、教程、示例代码或者测试用例,帮助用户理解和学习Ibatis的使用。 描述中的"一个很好的例子"提示我们,这个压缩包包含的内容可能是Ibatis的实际应用展示,可能是通过一个具体的项目或案例...

    ibatis学习笔记(一)

    这篇“ibatis学习笔记(一)”可能是博主对Ibatis基础概念、安装配置以及基本使用的介绍,让我们通过标签“源码”和“工具”来深入探讨Ibatis的相关知识。 首先,Ibatis是一个轻量级的Java ORM(对象关系映射)框架...

    Spring+iBatis+JOTM实现JTA事务

    本文将详细介绍如何使用Spring框架、iBatis(现称为MyBatis)和JOTM来实现Java Transaction API (JTA)的分布式事务处理。 #### 二、基础知识简介 **1. Spring框架** - **概述**:Spring是一个开源的轻量级Java...

    01第一天-mybatis-mybatis入门-介绍.mp4

    MyBatis的前身就是iBatis , MyBatis使用XML描述符或注释将对象与存储过程或SQL语句耦合,将关系数据库与面向对象应用程序结合使用变得更加容易。支持定制化SQL、存储过程以及高级映射。

    springboot ibaits mysql整合 01

    本教程将详细介绍如何将Spring Boot与iBatis以及MySQL数据库进行整合,为你的Web应用构建强大的数据处理能力。 首先,我们需要理解Spring Boot的核心特性。Spring Boot通过“约定优于配置”的原则,使得开发者能够...

    mybatis-day01培训内容1

    第二章介绍了Hibernate,这是一个流行的ORM(Object-Relational Mapping)框架,它消除了直接使用JDBC的许多麻烦。通过Hibernate,开发者可以使用面向对象的方式来操作数据库,无需关心底层的SQL语法。优点是简化了...

    Spring+SpringMVC+MyBatis+SpringBoot视频01

    《Spring+SpringMVC+MyBatis+SpringBoot视频01》是一套全面介绍Java开发中常用技术框架的教程,涵盖了Spring、SpringMVC、MyBatis和SpringBoot的核心概念和实战应用。以下是对这些标签及文件内容的详细解读: 1. **...

    2021年最新java面试题--视频讲解(内部培训84个知识点超详细).rar

    Java面试题01.面试的整体流程 Java面试题02.java的垮平台原理 Java面试题03.搭建一个java的开发环境 Java面试题04.java中int占几个字节 Java面试题05.java面向对象的特征 Java面试题06.装箱和拆箱 Java面试题07.==和...

    199-淘宝网架介绍.pdf

    - **核心组件**:使用EJB进行业务逻辑处理、Ibatis作为数据访问对象。 - **问题**:虽然性能有所提升,但仍存在开发效率低下、成本过高等问题。 ##### V2.1 (2004.10-2007.01) - **架构优化**:从WebLogic切换到...

    spring2.5 -3.0 hibernate3.3 jar包说明

    接下来,我们将详细介绍Spring 2.5至3.0版本中包含的关键Jar包及其功能: 1. **spring-core.jar** 这个Jar包包含了Spring框架的基础部分,是所有Spring应用的基础,提供了IoC容器的基础实现。它还包含了核心工具...

    IBM_Java 高级.课件

    5 CSS01讲义 6 servle技术初步入门 7 servle核心技术 8 JSP技术初步入门 9 JSP核心技术与应用 10 JSTL技术介绍 11 MVC框架技术实现 13 struts框架 14 持久层设计技术hibernate 15 spring框架 专题 信息分页 专题 ...

    mybatis_01 入门配置 Dao的两种开发方法

    - **MyBatis** 是 Apache 软件基金会下的一个开源项目,前身是 iBatis 框架。2010 年从 Apache 迁移到 Google Code 下,并更名为 MyBatis,后于 2013 年迁移到 GitHub ...

    通向架构师的道路(最全的资料)

    这个压缩包包含了一系列文档,详细介绍了不同主题,让我们逐一解析其中的重要知识点。 首先,我们看到关于IBM WebSphere的内容,这是一款强大的应用服务器,广泛用于企业级应用部署。"通向架构师的道路(第十五天)...

    最新Java面试题视频网盘,Java面试题84集、java面试专属及面试必问课程

    java面试题01.面试的整体流程.mp4 │ Java面试题02.java的垮平台原理.mp4 │ Java面试题03.搭建一个java的开发环境.mp4 │ Java面试题04.java中int占几个字节.mp4 │ Java面试题05.java面向对象的特征.mp4 │ Java...

    mybatis-plus配置控制台打印完整带参数SQL语句的实现

    本文将详细介绍如何在MyBatis-Plus中配置控制台打印这样的SQL。 首先,问题背景是开发人员在编写SQL语句时,通常需要结合控制台输出和数据库管理工具(如Navicat或PLSQL)来检查和验证SQL的正确性。如果只看到占位...

    java学习参考站点

    通过以上知识点的介绍,可以看出Sun官方及国内外技术社区为Java学习者提供了非常全面且实用的学习资源,涵盖了从基础概念到高级技术的应用。无论是初学者还是有经验的开发者,都可以从中找到适合自己水平的内容,...

    初识MyBatis

    MyBatis 使用简单的 XML 或注解进行配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 对象)映射成数据库中的记录。 MyBatis 最初是由 Apache 的一个开源项目 iBatis 发展而来的,在 ...

Global site tag (gtag.js) - Google Analytics