在JAVA EE应用程序中,持久层框架常用的有:Hibernate和IBATIS(或MyBatis),Hibernate是全自动的,IBatis是半自动的。

IBatis的主要的作用是把SQL语句从我们的应用程序中给抽离出来(把SQL语句写到相应的配置文件当中),实现应用程序和SQL语句的解耦,让我们的应用程序看上去更加优雅,也便于后期的维护。根据上述描述,IBatis框架要求程序熟稔掌握SQL语句的编写。

1.使用IBatis框架的步骤:

导入相应的jar包
配置IBatis的配置文件    sqlmapconfig.xml
配置映射文件
加载配置文件和映射文件获取SqlClientMap对象
使用SqlClientMap完成CRUD操作

2.为了在开发过程更加直观,我们需要将 ibatis 日志打开以便观察 ibatis 运作的细节。ibatis 采用 Apache common_logging,并结合 Apache log4j 作为日志输出组件。在CLASSPATH 中新建 log4j.properties 配置文件,内容如下:

log4j.rootLogger=debug,stdout,logfile
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout
log4j.appender.logfile=org.apache.log4j.FileAppender
log4j.appender.logfile.File=D:/test.log
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %F %p %m%n log4j.logger.com.ibatis=DEBUG
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=DEBUG
log4j.logger.com.ibatis.common.jdbc.ScriptRunner=DEBUG
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=DEBUG
log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG

  

3.配置文件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>
<!--
在ibatis中如果要加注释,一定要注意前后要有空格,否则iBATIS不能正确解析
配置文件 千万千万要注意
--> <!--
settings标签属性释义:
【cacheModelsEnabled】是否启用SqlMapClient上的缓存机制,建议启用
【enhancementEnabled】是否针对POJO实体启用字节码增强机制,以提升getter/setter
的调用效能,避免使用Java Reflect带来的性能开销。同时,这也为Lazy Loading带来了极大的性能提升
建议设置为true
【errorTracingEnabled】是否启用错误日志。在开发期间,建议启用,便于调试。
【lazyLoadingEnabled】是否启用延迟加载机制,建议启用
【useStatementNamespaces】是否使用Statement命名空间
这里命名命名空间指的是配置文件中SqlMap节点的namespace属性值,比如
<sqlMap namespace="User">
指定命名过后,且该值为true的情况下,那么在访问sql语句的时候就要加上命名空间,
比如:sqlMap.update("User.updateUser",user);
-->
<settings
useStatementNamespaces="true"
cacheModelsEnabled="true"
lazyLoadingEnabled="true"
enhancementEnabled="true"
/>
<!-- 指定事务管理策略为JDBC【即默认使用Connection对象的commit和rollback实现事务管理】 -->
<transactionManager type="JDBC">
<!-- dataSource用于配置数据源【数据库连接池】,它从属于transactionManager -->
<dataSource type="SIMPLE">
<property name="JDBC.Driver" value="oracle.jdbc.driver.OracleDriver"/>
<property name="JDBC.ConnectionURL" value="jdbc:oracle:thin:@localhost:1521:orcl"/>
<property name="JDBC.Username" value="scott"/>
<property name="JDBC.Password" value="orcl123"/>
<!-- 设置为自动提交,这样的话,就不用每一次都手动 提交 -->
<property name="JDBC.AutoCommit" value="true"/> <property name="Pool.MaximumActiveConnections" value="10"/>
<property name="Pool.MaximumIdleConnections" value="5"/>
<!-- 数据库连接池中的数据库连接对象被某一个任务占用的最大的时间,当超过这一时间,将被强制收回。
该属性值一般要指定大一点。
-->
<property name="Pool.MaximumCheckoutTime" value="150000"/>
<!-- 当一个线程需要数据库连接对象,而现在连接池中已经没有空闲的数据库连接对象了,
那么现在线程进入等待状态,该参数设置了线程最大等待多长时间。
-->
<property name="Pool.MaximumTimeToWait" value="500"/> <!--
连接状态检测语句
用于检查数据库连接池中的数据库连接对象是否可用。
避免用户拿到的是一个无效的数据库连接对象
-->
<property name="Pool.PingQuery" value="select 1 from User"/>
<!-- 是否运行检测连接状态 -->
<property name="Pool.PingEnabled" value="false"/>
<!-- 对持续连接时间超过设定值【毫秒】的连接进行检测 -->
<property name="Pool.PingConnectionsOrderThan" value="10"/>
<!-- 对空闲超过设定值【毫秒】的连接进行检测 -->
<property name="Pool.PingConnectionsNotUsedFor" value="10"/>
</dataSource>
</transactionManager> <!-- 在IBatis中,虽然不能称之为映射文件,但实体类对应的SQL语句配置文件还是尽量和实体类在同一路径下 -->
<sqlMap resource="pojo/User.xml"/> </sqlMapConfig>

4.USER

public class User {

	private int userid;
private String username;
private int age;
//省略 getter setter...
}

5.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 namespace="User"> <typeAlias alias="user" type="pojo.User"/> <select id="getUser" parameterClass="java.lang.String" resultClass="user">
select id,name,age from tuser where username=#name#
</select>
</sqlMap>

  

6.测试。

@Test
public void testGetUser(){
Reader reader = null;
try {
reader = Resources.getResourceAsReader("SqlMapConfig.xml");
SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(reader);
User user = new User();
user=(User) smc.queryForObject("User.getUser", "tom");
System.out.println(user.getUserid()+user.getUsername()+user.getAge());
} catch (IOException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} }

  

初识iBatis的更多相关文章

  1. ibatis的初识

    在工作中,服务端的框架基本上是struts+spring+ibatis+velocity.ibatis曾经没有接触到,而曾经使用的hibernate在公司居然没碰着.同样都是数据库封装,为什么没有选择 ...

  2. mybatis入门--初识mybatis

    初识mybatis 今天,一起来说说mybits这个框架吧.这是一个持久层的框架.之前叫做ibatis.所以,在它的代码中出现ibatis这个词的时候,不要感到惊讶.不是写错了,它确实就是这个样子的. ...

  3. MyBatis 框架系列之基础初识

    MyBatis 框架系列之基础初识 1.什么是 MyBatis MyBatis 本是 apache 的一个开源项目 iBatis,后改名为 MyBatis,它 是一个优秀的持久层框架,对 jdbc 的 ...

  4. MyBatis For .NET学习- 初识MyBatis

    MyBatis的框架. Introduction MyBatis本是apache的一个开源项目iBatis,2010年这个项目由 apache software foundation迁移到了googl ...

  5. 初识Mybatis之工程搭建

    简介:MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以使用简单的 ...

  6. MyBatis学习01(初识MyBatis和CRUD操作实现)

    1.初识MyBatis 环境说明: jdk 8 + MySQL 5.7.19 maven-3.6.1 IDEA 学习前需要掌握: JDBC MySQL Java 基础 Maven Junit 什么是M ...

  7. 值得注意的ibatis动态sql语法格式

    一.Ibatis常用动态sql语法,简单粗暴用一例子 <select id="iBatisSelectList" parameterClass="java.util ...

  8. org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):

    org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): da.huying.usermanag ...

  9. Android动画效果之初识Property Animation(属性动画)

    前言: 前面两篇介绍了Android的Tween Animation(补间动画) Android动画效果之Tween Animation(补间动画).Frame Animation(逐帧动画)Andr ...

随机推荐

  1. Android 性能优化(14)网络优化( 10)Determining and Monitoring the Connectivity Status

    Determining and Monitoring the Connectivity Status This lesson teaches you to Determine if you Have ...

  2. 创建maven项目遇到的问题

    1.新建完成的maven项目,缺少src/main/java 解决方案:把项目中的jre换成eclipse中默认的jre. 另外还可以参考:解决Eclipse建立Maven项目后无法建立src/mai ...

  3. 如何向expect脚本里面传递参数

    如何向expect脚本里面传递参数   比如下面脚本用来做ssh无密码登陆,自动输入确认yes和密码信息,用户名,密码,hostname通过参数来传递   ssh.exp   Python代码   # ...

  4. 微信小程序组件解读和分析:二、scroll-view可滚动视图区域

    scroll-view可滚动视图区域组件说明: 可滚动视图区域. 组件用法:纵向滚动用法 Tip: 使用竖向滚动时,需要给一个固定高度,通过 WXSS 设置 height,否则无法滚动. 当滚动到顶部 ...

  5. TortoiseSVN客户端不能记住用户名和密码

    TortoiseSVN客户端重新设置用户名和密码 在第一次使用TortoiseSVN从服务器CheckOut的时候,会要求输入用户名和密码,这时输入框下面有个选项是保存认证信息,如果选了这个选项,那么 ...

  6. java正则表达式匹配字符

    假设要匹配${2}中间为数字的这个类型的变量String,则 Pattern p = Pattern.compile("\\$\\{\\d+\\}"); Matcher m = p ...

  7. 动态设置缩放比例和html字体大小

    <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8& ...

  8. day20-面向对象基础

    目录 面向对象基础 面向过程编程与面向对象编程 面向过程编程 面向对象编程 类与对象 类 对象 定义类和对象 定制对象独有特征 对象属性查找顺序 类与对象的绑定方法 类与数据类型 对象的高度整合 面向 ...

  9. 让元素div消失在视野中

    让元素div消失在视野中1.position:absolute/relative/fixed + 方位 top/bottom/left/right: -9999px2.display:none3.vi ...

  10. buf.readInt16BE()

    buf.readInt16BE(offset[, noAssert]) buf.readInt16LE(offset[, noAssert]) offset {Number} 0 noAssert { ...