iBatis框架使用 4步曲
iBatis是一款使用方便的数据訪问工具,也可作为数据持久层的框架。和ORM框架(如Hibernate)将数据库表直接映射为Java对象相比。iBatis是将SQL语句映射为Java对象。
相对于全自己主动SQL的Hibernate,iBatis同意你对SQL有全然控制权,能够视为半自己主动的数据訪问工具。
iBatis的最大长处是简便,轻量级,仅需iBatis的一个jar和数据库的驱动就可以执行,并且使用iBatis仅需掌握SQL和XML的使用方法就可以,而不像Hibernate那样须要配置对象间的关系。学习iBatis的过程要比Hibernate快非常多,在项目中,若人员水平不大一致时。使用iBatis取代Hibernate作为数据訪问工具能够有效提升开发效率。
无论是iBatis还是Hibernate。都作为訪问数据库的工具,它们必定基于JDBC而来,目的解决是JDBC程序开发的繁琐性和代码的冗余性(如载入驱动,建立连接,初始化语句对象,运行数据库操作。返回结果,关闭各个对象这一反复且无技术含量的过程)。
iBatis框架是Java持久层开发框架,说白了就是前人写了一部分代码(针对数据库操作),我们要做的就是再次开发,拿来框架直接使用。
我们自己开发时,dao层的sql语句都是写死在程序中的。假设查询条件改变什么的都须要改动sql语句,这样就得去改动原代码,违背了开发原则中的开闭原则。有没有一种实现让sql不再写死在程序里,iBatis框架就能够使sql文活起来。
iBatis是一个开源的项目。有兴趣的能够去看看那些元老级的人物是怎么将封装的框架。本文旨在介绍它的使用。
第一步:搭建好开发环境
所谓的搭建好开发环境就是拷贝iBatis的jar包到我们的项目中。这样我们就能够使用框架中的相关类啦。
因为iBatis是数据库方面的操作,所以还有加入数据库方面的jar包,我用的是oracle的数据库,所以得到oracle的安装文件夹以下去找链接数据库的ojdbc6.jar
第二步:编写实体类和dao层接口及实现
这里须要做的就是将数据库的表相应封装成对象实体。定义Dao层的接口和实现,接口的详细实现这里不须要写,仅仅须要把类准备出来,把接口准备出来就能够拉。
第三步:拷贝xml文件
将iBatis中的两个xml文件复制到项目中(下载的iBatis资料中会有相应的jar包和简单的样例,样例中有xml文件),一个是SqlMapConfig.xml是完毕数据库配置的文件。还有一个是实体类相应的xml文件,本文以User.xml为例。
须要注意的是这两个文件所放的位置,一般都是将SqlMapConfig.xml文件复制到项目的根文件夹以下。放在src下。实体类相应的xml文件跟相应的实体放在一块即可了。
一个系统中就仅仅有一个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="oracle.jdbc.driver.OracleDriver"/>
- <property name="JDBC.ConnectionURL" value="jdbc:oracle:thin:@localhost:1521:Orl"/>
- <property name="JDBC.Username" value="scott"/>
- <property name="JDBC.Password" value="tiger"/>
- </dataSource>
- </transactionManager>
- <sqlMap resource="com/ibatis/bean/User.xml"/>
- </sqlMapConfig>
实体类的配置文件则有多个。是和实体类相应的。
内容參考例如以下:
- <?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>
- <!--起别名-->
- <typeAlias alias="UserType" type="com.ibatis.bean.User"></typeAlias>
- <!--insert操作,parameterClass为參数的类型-->
- <insert id="insertUserID" parameterClass="UserType">
- insert into t_user (
- username,
- userpswd)
- values (
- #username#, #userpswd#
- )
- </insert>
- <delete id="deleteUser" parameterClass="java.lang.String">
- delete from t_user where username=#username#
- </delete>
- </sqlMap>
第四步:编写dao层接口实现
用了框架后。实现类中就没有sql语句了。在上面參考代码中看到,sql语句都配置到相应的实体类相应的配置文件里拉,这样实现类的代码就会变得非常easy。例如以下:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbGlzaHVhbmd6aGU3MDQ3/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" style="border:none; max-width:100%">
这样就能够实现对User的加入和删除了,假设此时还不放心。能够加入个測试类測试一次。
使用框架,前提配置工作一定要做好。主要在配置文件上面。一定要细致。
版权声明:本文为博主原创文章。未经博主同意不得转载。
iBatis框架使用 4步曲的更多相关文章
- Membership三步曲之进阶篇 - 深入剖析Provider Model
Membership 三步曲之进阶篇 - 深入剖析Provider Model 本文的目标是让每一个人都知道Provider Model 是什么,并且能灵活的在自己的项目中使用它. Membershi ...
- Membership三步曲之入门篇 - Membership基础示例
Membership 三步曲之入门篇 - Membership基础示例 Membership三步曲之入门篇 - Membership基础示例 Membership三步曲之进阶篇 - 深入剖析Pro ...
- iBatis框架基本使用
iBatis框架是Java持久层开发框架,说白了就是前人写了一部分代码(针对数据库操作),我们要做的就是再次开发,拿来框架直接使用. 我们自己开发时,dao层的sql语句都是写死在程序中的,如果查询条 ...
- [转]Membership三步曲之入门篇 - Membership基础示例
本文转自:http://www.cnblogs.com/jesse2013/p/membership.html Membership三步曲之入门篇 - Membership基础示例 Members ...
- ASP.NET 安全系列 Membership三步曲之入门篇 - Jesse Liu
Membership 三步曲 ASP.NET 安全系列 Membership三步曲之入门篇 ASP.NET 安全系列 Membership三步曲之进阶篇 ASP.NET 安全系列 Membership ...
- iBatis框架batch处理优化 (转)
为什么要做batch处理 这个问题我就不解释了,因为我想你们肯定能比我解释的更好!如果你真的不知道,那就到Google上去搜索一下吧☻Oracle回滚段 这个问题偶也不很明白,只是 ...
- Java EE注册三部曲(一步曲)
一步曲(html+servlet+SQL+Bean+Dao+加密(Base64)) 设计思路: 1:编写前台页面jsp:register.jsp,使得用户能够实行注册操作 2:编写servlet:re ...
- 第七章 new的三步曲
这章是本系列文章的重点,这章揭示了js对象的真正本质 看下面的事例 var a = new b(); 等价于 ①var a={}; ②a.__proto__=b.prototype; ③b.call( ...
- iBatis框架简介
一.为啥使用iBatis? 在 Hibernate.JPA 这样的一站式对象 / 关系映射(O/R Mapping)解决方案盛行之前,iBaits 基本是持久层框架的不二选择.即使在持久层框架层出不穷 ...
随机推荐
- VB学习生成JavaBean
Application.ActiveWorkbook.Path 获取当前excel文件所在的文件地址 Excel VBA中表示当前工作簿,有Activeworkbook和Thisworkbook 两种 ...
- UVA-11584 Partitioning by Palindromes 动态规划 回文串的最少个数
题目链接:https://cn.vjudge.net/problem/UVA-11584 题意 给一个字符串序列,问回文串的最少个数. 例:aaadbccb 分为aaa, d, bccb三份 n< ...
- 【转载】python学习之 字符串前'r'的用法
文章转载:https://www.cnblogs.com/cyiner/archive/2011/09/18/2180729.html 在打开文件的时候open(r'c:\....') 加r和不加'' ...
- 紫书 习题 11-7 UVa 10801 (单源最短路变形)
把每个电梯口看作一个节点, 然后计算边的权值的时候处理一下, 就ok了. #include<cstdio> #include<vector> #include<queue ...
- [HAOI2009]毛毛虫(树形dp)
[HAOI2009]毛毛虫 题目描述 对于一棵树,我们可以将某条链和与该链相连的边抽出来,看上去就象成一个毛毛虫,点数越多,毛毛虫就越大.例如下图左边的树(图 1 )抽出一部分就变成了右边的一个毛毛虫 ...
- MAVEN flex
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...
- unity Android在streamingAssets路径下文件无法读取的的解决方法
unity Android在streamingAssets路径下文件,有时候plugin下的.jar或者.so无法直接读取: 解决方法之一,拷贝至其他路径: #if UNITY_ANDROID str ...
- POJ 2375 Cow Ski Area
Cow Ski Area Time Limit: 1000ms Memory Limit: 65536KB This problem will be judged on PKU. Original I ...
- asp.net 缓存公共类
using System; using System.Collections.Generic; using System.Text; using System.Web; using System.We ...
- 使用Qt.labs.settings来存储应用的设置
我在曾经的文章中,讲述了怎样使用U1db及SQLite offline storage API来存储应用的一些状态.在这篇文章中,我将介绍怎样使用Qt.labs.settings来存储应用的状态.更加 ...