resultMap构成

<resultMap id="" type="">
		<constructor>
			<idArg></idArg>
			<arg></arg>
		</constructor>
		<id/>
		<result/>
		<association property=""/>
		<collection property=""/>
		<discriminator javaType="">
			<case value=""></case>
		</discriminator>
	</resultMap>

constructor:用于配置构造方法。一个POJO可能不存在没有参数的构造方法,可以使用constructor进行配置。 

一个用户类User不存在没有参数参数的构造方法,它的构造方法声明为

public UserBean(Integer id, String userName)

那么我们的配置如下

<constructor>
			<idArg column="id" javaType="int"/>
			<arg column="user_name" javaType="string"/>
		</constructor>

id:表示那个列是主键,允许多个主键的存在,多个主键成为联合主键。

result:配置POJO到SQL列名的映射关系。

result元素和idArg元素的属性

元素

 说明

 注意

property

 映射到列结果的字段或属性。如果POJO的属性匹配的是存在的却给定SQL列名(column)相同,这样Mybatis就会映射到POJO上

可以使用导航式字段,如用户为(User)需要使用姓名时(name),就可以写为user.name

column

 对应的是SQL的列

 

javaType

 配置Java的类型

 可以是特定的类完全限定名或者MyBatis上下文的别名

jdbcType

 配置数据库类型

 MyBatis已经做了限定, 支持大部分的数据库

typeHandle

类型处理器

 允许用特定的处理器来覆盖MyBatis默认的处理器,这就要制定jdbcType和javaType相互转化的规则

使用map存储结果集

任何select语句都可以使用map存储

<select id="findUserByNote" parameterType="string" result="map">
	select id, name ,note from t_user where note like concat('%', #{note}, '%')
</select>

 我们简单知道map结果集就好,因为使用map接口就意味着可读性的下降

所以我们推荐使用POJO方式

使用POJO存储结果集

一方面可以使用自动映射,正好使用resultType属性一样,但是有时候需要更为复杂的映射或者级联,这个时候还可以使用select语句的resultMap属性配置映射集合,只是使用前要配置类似的resultMap,如下

<resultMap id="userResultMap" type="com.learn.smm.pojo.User">
	<id property="id" column="id"/>
	<result property="userName" column="user_user"/>
	<result property="note" column="note"/>
</resultMap>
  • resultMap元素的属性id代表这个resultMap的标识,type代表着需要映射的POJO,这里可以使用MyBatis定义好的类的别名,也可以使用自定义的类的全限定名。
  • 载映射关系中,id元素表示表示这个对象的主键,property代表着POJO的属性名称,column表示数据库中SQL的列名,于是POJO就和数据库SQL的结果一一对应起来了。然后在映射文件中的select元素里如下代码中,便可使用resultMap了。
<select parameterType="long" id="getUser" resultMap="userResultMap">
	select id, user_name, note from t_user where id = #{id}
</select>
  • 在使用XML配置时,可以配置typeHandler、javaType、jdbcType等
  • 但配置了resultMap就不可以resultType了

下一节中我们讲级联,一个更为复杂的关系属性