ibatis实战之OR映射
相对Hibernate等ORM实现而言,ibatis的映射配置更为简洁直接,以下是一个典型的配置文件。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap
PUBLIC "-//iBATIS.com//DTD SQL Map 2.0//EN"
"http://www.ibatis.com/dtd/sql-map-2.dtd">
<sqlMap namespace="User">
<!-- 模块配置 -->
<typeAlias alias="user" type="com.itmyhome.User" /> <cacheModel id="userCache" type="LRU">
<flushInterval hours="24"/>
<flushOnExecute statement="updateUser"/>
<property name="size" value="1000" />
</cacheModel> <!-- Statement配置 -->
<select id="getUser" parameterClass="java.lang.String" resultClass="user" cacheModel="userCache">
<![CDATA[
select * from user where id = #id#
]]>
</select> <insert id="insertUser" parameterClass="user">
insert into user values(#id#,#name#,#age#)
</insert> <update id="updateUser" parameterClass="user">
update user set name = #name# where id = #id#
</update> </sqlMap>
能够看到,映射文件主要分为两个部分:模块配置和Statement配置
一、模块配置包含:
typeAlias节点:
定义了本映射文件里的别名,以避免过长变量值的反复书写,此例中通过typeAlias节点为类"com.itmyhome.User"定义了一个别
名"user",这样在本配置文件的其它部分,须要引用"com.itmyhome.User"类时,仅仅需以其别名替代就可以。
cacheModel节点
定义了本映射文件里使用的Cache机制
<cacheModel id="userCache" type="LRU">
<flushInterval hours="24"/>
<flushOnExecute statement="updateUser"/>
<property name="size" value="1000" />
</cacheModel>
这里声明了一个名为"userCache"的cacheModel,之后能够在Statement声明中对其进行引用
<select id="getUser" parameterClass="java.lang.String" resultClass="user" cacheModel="userCache">
这表明对通过id为"getUser"的Select statement获取的数据,使用cacheModel"userCache"进行缓存。
之后假设程序再次用此Statement进行数据查询,即直接从缓存中读取查询结果,而无需再去数据库查询。
cacheModel主要有以下几个配置点:
flushInterval:设定缓存有效期,假设超过此设定值,则将此CacheModel的缓存清空。
size:本CacheModel中最大容纳的数据对象数量。
flushOnExecute:指定执行特定Statement时,将缓存清空。如updateUser操将更
新数据库中的用户信息,这将导致缓存中的数据对象与数据库中的实际
数据发生偏差,因此必须将缓存清空以避免脏数据的出现。
二、Statement配置
Statement配置包含了数个与SQL Statement相关的节点,分别为:
1)statement
2)insert
3)delete
4)update
5)select
6)procedure
当中,statement最为通用,它能够替代其余的全部节点。除statement之外的节点各自相应了SQL中的
同名操作(procedure相应存储过程).使用statement定义全部操作固然能够达成目标,但缺乏直观性,
建议在实际开发中依据操作目的,各自选用相应的节点名加以申明.一方面,使得配置文件
更加直观,还有一方面,也可借助DTD对节点申明进行更有针对性的检查,以避免配置上的失误。
基本的配置项例如以下:
<statement id="queryUser" parameterClass="java.lang.Integer" resultClass="user">
select * from user where id = #id#
</statement> <select id="getUser" parameterClass="java.lang.String"
resultClass="user" cacheModel="userCache">
<![CDATA[
select * from user where id = #id#
]]>
</select> <insert id="insertUser" parameterClass="user">
insert into user values(#id#,#name#,#age#)
</insert> <update id="updateUser" parameterClass="java.lang.Integer">
update user set name = #name# where id = #id#
</update> <delete id="deleteUser" parameterClass="java.lang.Integer">
delete user where id = #id#
</delete>
參数 | 描写叙述 |
parameterClass | 參数类.指定了參数的完整类名(包含包路径). 可通过别名避免每次反复书写冗长的类名. |
resultClass | 结果类.指定结果类型的完整类名(包含包路径) 可通过别名避免每次反复书写冗长的类名. |
parameterMap | 參数映射,需结合parameterMap节点对映射关系加以定义. 对于存储过程之外的statement而言,建议使用 parameterClass作为參数配置方式,一方面避免了 參数映射配置工,还有一方面其性能表现也更加出色。 |
resultMap | 结果映射,需结合resultMap节点对映射关系加以定义。 |
cacheModel | statement相应的Cache模块。 |
对于參数定义而言,尽量使用parameterClass,即直接将POJO作为statement的调用參数,
这样在SQL中能够直接将POJO的属性作为參数加以设定,如:
<update id="updateUser" parameterClass="com.itmyhome.User">
alter table user set name = #name# where id = #id#
</update>
这里将com.itmyhome.User类设定为updateUser的參数之后,我们就可以在SQL中通过#name#
对POJO的属性进行引用。例如以下:
set name = #name# where id = #id#
执行期,ibatis将通过调用User对象的getName,getId方法获得相应的參数值,并将其作为SQL的參数。
假设parameterClass中设定的是jdk的中的简单对象类型,如String、Integer,ibatis会直接将其作为SQL中的參数值。
我们也能够将包含了參数数据的Map对象传递给Statement如:
<update id="updateUser" parameterClass="java.util.Map">
update user set name = #name# where id = #id#
</update> Map<String, Object> map = new HashMap<String,Object>();
map.put("id", "1");
map.put("name", "hello");
sqlMap.update("updateUser",map);
这里传入的參数就是一个Map对象,ibatis将以key "id"、"name"从中提取相应的參数值
在SQL中设定參数名时,能够同一时候指定參数类型,如:
update user set name = #name:VARCHAR# where id = #id:NUMBERIC#
ibatis实战之OR映射的更多相关文章
- ibatis实战之插入数据(自动生成主键)
ibatis实战之插入数据(自动生成主键) --------- 如果你将数据库设计为使用自动生成的主键,就可以使用ibatis的<selectKey>元素(该元素是<insert&g ...
- ibatis实战之基础环境搭建
关于ibatis的介绍.优缺点,以及ibatis和hibernate的比较再此不在赘述,可参阅其他资料. 一.准备工作 1.下载ibatis软件包http://download.csdn.net/de ...
- 《深入浅出MyBatis技术原理与实战》——4. 映射器,5. 动态SQL
4.1 映射器的主要元素 4.2 select元素 4.2.2 简易数据类型的例子 例如,我们需要统计一个姓氏的用户数量.应该把姓氏作为参数传递,而将结果设置为整型返回给调用者,如: 4.2.3 自动 ...
- 第十三篇:一点一滴学ibatis(二)映射文件
首先给出一个常见的映射文件局部模板 <?xml version="1.0" encoding="utf-8" ?><!DOCTYPE s ...
- Java实战之02Hibernate-02映射、一级缓存、实体对象状态
五.映射基础 1.实体类采用javabean的编写规范 JavaBean编写规范: a.类一般是public的 b.有默认的构造方法 c.字段都是私有的 d.提供公有的getter和setter方法 ...
- [原创+实战+钓鱼]setoolkit+映射
所需工具:setoolkit,花生壳 (此方法主要针对没有服务器,没有空间的攻击者.有服务器或者空间可以直接上传setoolkit的生成源码到服务器或者空间.) 1.setoolkit克隆一个站点 | ...
- ibatis实战之一对多关联
在实际开发中,我们常常遇到关联数据的情况,如User对象拥有若干Book对象 每个Book对象描述了归属于一个User信息,这种情况下,我们应该如何处理? 通过单独的Statement操作固然可以实现 ...
- ibatis实战之中的一个对多关联
在实际开发中,我们经常遇到关联数据的情况,如User对象拥有若干Book对象 每一个Book对象描写叙述了归属于一个User信息,这样的情况下,我们应该怎样处理? 通过单独的Statement操作固然 ...
- SpringMVC实战(三种映射处理器)
1.前言 上一篇博客,简单的介绍了一下SpringMVC的基础知识,这篇博客来说一下SpringMVC中的几种映射处理器机制. 2.三种映射处理器 2.1 BeanNameUrlHandlerMapp ...
随机推荐
- 指尖上的电商---(3)Solr全文搜索引擎的配置
接上篇,Solr的准备工作完毕后,本节主要介绍Solr的安装,事实上Solr不须要安装.直接下载就能够了 1.Solr配置 下载地址 :http://lucene.apache.org/so ...
- 使用git微命令深入理解git工作机制
首先.这篇不是真正意义上的翻译,所以大家在看的时候不要找相应的英文文章相应着看.这篇文章之所以归类为翻译.是由于最開始有一篇英文文章让我对git内部机制有了清楚的认识,它能够说是我git的启蒙老师吧. ...
- 近期在调用 calendar.js 的时候出现中文乱码! 解决方式
近期写一个小项目的时候:在调用 calendar.js 的时候出现中文乱码! 如图所看到的: 原因在于: 我的jsp 页面,指定的是 UTF-8 编码,然而,调用的 calendar.js 的编码确 ...
- JavaFX游戏开发效率浅谈
声明: 本博客文章原创类别的均为个人原创,版权所有.转载请注明出处: http://blog.csdn.net/ml3947,另外本人的个人博客:http://www.wjfxgame.com. ...
- R语言数据框行转列实例
目的:须要把数据框的行列进行转置 方法: # 原始数据框 > hrl_jd_mon 年份 一月 二月 三月 四月 五月 六月 七月 八月 九月 十月 十一月 十二月 1 2010年 51 ...
- Unigine 基础入门
1. 首先要搭建好开发环境: 1)Visual Stodio 已经安装了. 2). Microsoft Windows SDK 7.1 (for Windows 7): https://www.mic ...
- C# openfiledialog设置filter属性后达不到过滤效果的原因之一
此处用RichTextBox控件举例>>> 在窗体对应的类中处理Load事件可以为openfiledialog设置Filter的属性: private void Form1_Load ...
- HDU 2255 奔小康,赚钱(KM算法模板)
解决问题的思路: 二部图,正确的匹配,卡费用流,使用KM算法. #include <cstring> #include <algorithm> #include <cst ...
- 苹果iOS手机系统诊断功能是后门吗?
7月20日,美国知名苹果iOS手机系统侦破专家扎德尔斯基在2014年世界黑客大会(HOPE/X)用幻灯片讲演揭露了苹果手机存在系统级"后门". 为此,7月23日.苹果公司马上做出回 ...
- 【解决方法】ADT在线安装
作为android开发者,不知道被ADT更新.SDK更新这些更新给强奸了多少次. 今天……我又一次被凌辱了. 无论是 https://dl-ssl.google.com/android/eclipse ...