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 基本是持久层框架的不二选择.即使在持久层框架层出不穷 ...
随机推荐
- 浏览器 滚动条 占据 y轴宽度的解决方案
html { overflow-y: scroll; } :root { overflow-y: auto; overflow-x: hidden; } :root body { position: ...
- HDU-1043 Eight八数码 搜索问题(bfs+hash 打表 IDA* 等)
题目链接 https://vjudge.net/problem/HDU-1043 经典的八数码问题,学过算法的老哥都会拿它练搜索 题意: 给出每行一组的数据,每组数据代表3*3的八数码表,要求程序复原 ...
- CF1065D Three Pieces (多元最短路)
题目大意:给你一个棋盘,你需要控制棋子依次经过编号为1~n的所有点,棋子的可以是车,马,象,都依照国际象棋的行棋方式,每走一步消耗1单位时间,但每次更换棋子都需要额外1单位时间,求经过所有点需要的最少 ...
- caioj 1158 欧拉函数
直接套模板,这道题貌似单独求还快一些 解法一 #include<cstdio> #include<cctype> #define REP(i, a, b) for(int i ...
- 紫书 例题 11-14 UVa 1279 (动点最小生成树)(详细解释)
这道题写了好久-- 在三维空间里面有动的点, 然后求有几次最小生成树. 其实很容易发现, 在最小生成树切换的时候,在这个时候一定有两条边相等, 而且等一下更大的那条边在最小生成树中,等一下更小的边不在 ...
- Mysql学习总结(27)——Mysql数据库字符串函数
注:sql的移植性比较强,函数的移植性不强,一般为数据库软件特有,例如mysql有mysql的函数,oracle有oracle的函数. 1.concat连接字符串: 从上图中可以看出,直接使用sele ...
- 将Spring Boot应用程序迁移到Java9:兼容性
将 Spring Boot 应用程序迁移到 Java 9:兼容性 随着 Java 9 的到来,关于如何迁移应用程序以使用模块系统有很多的讨论.遗憾的是,大多数文章的焦点都集中于简单的 Hello Wo ...
- Android蓝牙技术Bluetooth使用流程(具体解释)
一:蓝牙设备之间的通信主要包含了四个步骤 设置蓝牙设备 寻找局域网内可能或者匹配的设备 连接设备 设备之间的传输数据 二:详细编程实现 1. 启动蓝牙功能 首先通过调用静态方法getDefaultAd ...
- python批量下载色影无忌和蜂鸟的图片 爬虫小应用
有些冗余信息.由于之前測试正則表達式.所以没有把它们给移走.只是不影响使用. # -*- coding:utf-8 -*- import re,urllib,sys,os,time def getAl ...
- 一步一步跟我学习lucene(19)---lucene增量更新和NRT(near-real-time)Query近实时查询
这两天加班,不能兼顾博客的更新.请大家见谅. 有时候我们创建完索引之后,数据源可能有更新的内容.而我们又想像数据库那样能直接体如今查询中.这里就是我们所说的增量索引.对于这种需求我们怎么来实现呢?lu ...
