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了
下一节中我们讲级联,一个更为复杂的关系属性