对mybatis的结果映射做个整理,只针对resultType/resultMap讨论,忽略sql语句的实现
1.将查询出的单行单列结果映射到java对象中的字段
例1:查询总记录数,返回一个Integer类型的对象即可
mapper.xml中,resultType=“Integer”;
mapper接口中,返回值为Integer即可
例2:查询某个用户的用户名username,返回一个java类对象A
要求:A类中的属性名要与查询出的字段名一致,否则要使用resultMap来映射,这里假设A类中已存在属性username
mapper.xml中,resultType=“A”(未在sqlMapper.xml中设置别名的话,这里就要写全限定类名xxx.xxx.A)
mapper接口中,返回值为A对象即可
2.将查询出的单行结果映射成java对象
即查询出的结果字段都映射到一个java对象的属性中去,跟上面的例2一样。如果java对象中的属性名和查询出的字段的列名是对应的,就能直接映射到java对象的属性中去,如果不对应,就要使用resultMap。
resultMap:
<resultMap type=“xxx.xxx.A” id=“resultMap1”>
<id column="id" property="id" />
<result column="" property=""/>
<result column="" property=""/>
</resultMap>
<