mybatis xml文件解析
1 parameterType
如果参数只有一个,比如一个id,即int类型的id,那么parameterType直接是int。
如果参数有多个,那么就用表中一行对应的类,默认是类的名字和表中列的名字相同的话,就进行赋值。
2 resultMap
用于告诉mabatis如何把select结果中取出的数据转换成开发者需要的对象。
由于是转换成开发者需要的对象,因此应该和SqlSession类的方法一起来看。
T selectOne(String statement);
这个时候就返回一个T类型的对象,这个对象是由resultMap里面的逻辑将数据库的查询结果转换而成的。
如果是
List<E> selectList(String statement);
这个时候返回的是一个E类型对象的列表,该列表中的每个对象是由resultMap里面的逻辑将数据库的查询结果转换而成的。
2.1 <result>标签
property指的是返回的对象的属性名,而column是查询结果的列名。result标签将它们对应起来,从而完成将数据库查询结果到开发者需要的对象的转换。
2.2 一对一的关系用association、一对多的关系用collection
它们是用来描述对象之间的引用关系的。
2.3 type属性
表示该resultMap返回的对象的类型。
2.4 <id> 标签和<result>标签的区别
它们都是类的属性到列的映射,但是id表示的是主键。
3 一对一关系的resultMap
一般情况下,一个对象里面会引用另外一个对象,这种情况就是一对一关系。
一个resultMap映射的只是一个对象,因此要在该对象中引用另外一个对象就需要用到另外一个resultMap,并且需要调用select来返回这个对象。
这个时候就用到了association标签了。它依然建立的是类的属性到查询到的数据之间的映射,但是这里查询到的数据用到了另外一个select的结果。
3.1 assotiation的property属性
该assotiation所在的resultMap返回的对象的属性。
3.2 assotiation的column属性
resultMap对象的表的列属性。用来向select传递参数。
3.3 assotiation的javaType属性
property属性的类型。
3.4 select
用来返回关联对象的select查询。
4 一对多关系的resultMap
如果一个对象里面引用到另外一个对象的集合,这种情况就是一对多关系。同样,也需要用到另外一个resultMap,并且也需要调用select来返回这个对象集合。这个时候要用到collection标签。
4.1 collection的property属性
该collection所在的resultMap返回的对象的属性。
4.2 collection的column属性
resultMap对象的表中的列的属性。用来给select传参。
4.3 collection的javaType属性
property属性的类。
4.4 collection的ofType属性
collection中单个元素的类型。
4.5 select
用于返回关联对象的select查询。
5 resultMap和resultType
用resultType的时候mybatis自动生成相应的resultMap,所使用的类型是java Bean,并且其属性名要和对应的数据库表中的列名相同。resultMap的话,就都是自己定义的,没有这些限制。也就是说,简单的对象类型可以用resultType,因为方便,但是复杂的返回类型就要用resultMap了。
mybatis xml文件解析的更多相关文章
- 通过正则表达式实现简单xml文件解析
这是我通过正则表达式实现的xml文件解析工具,有些XHTML文件中包含特殊符号,暂时还无法正常使用. 设计思路:常见的xml文件都是单根树结构,工具的目的是通过递归的方式将整个文档树装载进一个Node ...
- 八、Android学习第七天——XML文件解析方法(转)
(转自:http://wenku.baidu.com/view/af39b3164431b90d6c85c72f.html) 八.Android学习第七天——XML文件解析方法 XML文件:exten ...
- android基础知识13:AndroidManifest.xml文件解析
注:本文转载于:http://blog.csdn.net/xianming01/article/details/7526987 AndroidManifest.xml文件解析. 1.重要性 Andro ...
- Android之AndroidManifest.xml文件解析
转自:Android学习笔记之AndroidManifest.xml文件解析 一.关于AndroidManifest.xml AndroidManifest.xml 是每个android程序中必须的文 ...
- 9.XML文件解析
一.XML简介 XML(EXtensible Markup Language),可扩展标记语言 特点:XML与操作系统.编程语言的开发平台无关 实现不同系统之间的数据交换 作用:数据交互 配置应用程序 ...
- Python实现XML文件解析
1. XML简介 XML(eXtensible Markup Language)指可扩展标记语言,被设计用来传输和存储数据,已经日趋成为当前许多新生技术的核心,在不同的领域都有着不同的应用.它是web ...
- Python3将xml文件解析为Python对象
一.说明 从最开始写javascript开始,我就很烦感使用getElementById()等函数来获取节点的方法,获取了一个节点要访问其子孙节点要么child半天要么就再来一个getElementB ...
- XML文件解析-DOM4J方式和SAX方式
最近遇到的工作内容都是和xml内容解析相关的. 1图片数据以base64编码的方式保存在xml的一个标签中,xml文件通过接口的方式发送给我,然后我去解析出图片数据,对图片进行进一步处理. 2.xml ...
- java基础之概谈xml文件解析
XML已经成为一种非常通用的数据交换格式,它的平台无关性,语言无关性,系统无关性,给数据集成与交互带来了极大的方便. 诸多web应用框架,其可配置的编程方式,给我们的开发带来了非常大程度的便捷,但细细 ...
随机推荐
- oracle用户密码错误导致用户锁定
解决方法:使用DBA用户将其解锁: SQL> alter user ecology account unlock; 用户已更改. 用户密码限制设置: 查看FAILED_LOGIN_ATTEMPT ...
- P2949 [USACO09OPEN]工作调度Work Scheduling
题目描述 约翰有太多的工作要做.为了让农场高效运转,他必须靠他的工作赚钱,每项工作花一个单位时间. 他的工作日从0时刻开始,有10^8个单位时间.在任一时刻,他都可以选择编号1~N的N(1 <= ...
- 【二叉搜索树】poj 1577 Falling Leaves
http://poj.org/problem?id=1577 [题意] 有一颗二叉搜索树,每次操作都把二叉搜索树的叶子从左到右揪掉(露出来的父节点就变成了新的叶子结点) 先给出了揪掉的叶子序列(多个字 ...
- servlet对form提交的数据进行XML转换后发送
今天遇到一个项目,要求对form表单提交的数据进行以xml格式发送出去: 直接写XMLUtil工具类如下: package com.yfit.controller; import javax.serv ...
- 2013年EI收录的中国期刊
ISSN 刊名 0567-7718 Acta Mechanica Sinica 1006-7191 Acta Metallurgica Sinica (English Letters) 0253-48 ...
- 线程池的使用。好文。mark【http://blog.csdn.net/rwecho/article/details/21157289】
介绍new Thread的弊端及Java四种线程池的使用,对Android同样适用.本文是基础篇,后面会分享下线程池一些高级功能. 1.new Thread的弊端执行一个异步任务你还只是如下new T ...
- 修改系统dpi
系统dpi设置不合理,会导致屏幕显示效果差.配置系统dpi设置ro.sf.lcd_density的值即可,不同项目设置位置不同,以高通为例:需要修改 项目/device/qcom/common/roo ...
- 51nod1053 最大M子段和 V2
$n \leq 50000$的序列,问选不超过$m \leq 50000$个区间使得和最大. 如果正数区间总数比$m$小那肯定全选.否则有两种方式减少区间数量:丢掉一个正区间:补一个负区间连接两个正区 ...
- linux的内存性能评估
linux的内存性能评估 参考自:自学it网,http://www.zixue.it/. (1)使用free指令监控内存,参数-m以M为单位显示,-h人性化显示单位. [test@localhost ...
- Linux设置文件与Shell操作环境
Shell设置文件读取流程 /etc/shells记录了Linux系统中支持的所有shell,默认使用bash.用户登入Linux系统时会获取到一个shell,具体获取到哪个shell与登录账号有关, ...