MyBatis自定义关系映射及实现分页查询
ResultMap 映射定义
当属性和表的字段不一致时,如果在映射文件中还是使用resultType就无法创建出对象
解决方法只能自己实现关系的映射,默认如果属性和字段是一致的情况下MyBatis自动创建一个resultMap进行关系映射
如果使用自定义的resultMap返回的类型就不能再使用resultType,必须使用resultMap
<mapper namespace="com.motianjie.dao.DeptVoMapper"> <select id="findDeptVo" parameterType="integer" resultMap="deptMap"> select deptno,dname,loc from dept where deptno=#{deptno} </select> //resultMap 映射实体类的属性和表之间的关系 // type:设置哪个实体类进行关系映射 //id 其他地方需要引用该resultMap的唯一标识 <resultMap type="DeptVo" id="deptMap"> //result 查询某行的某个字段 //property 实体类属性 //column 数据库表的字段名 //javaType 实体类的属性的类型 可以用java的类型 也可使用mybatis的简写类型(类型的首字母小写) //jdbcType 数据库字段的类型 规则:把数据库的类型改成全大写 <result property="id" column="deptno" javaType="integer" jdbcType="INTEGER"/> <result property="deptname" column="dname" javaType="string" jdbcType="VARCHAR"/> <result property="location" column="loc"/> </resultMap>
使用Mapper映射器
a.该接口中的方法和映射文件中定义的语句一一对应。接口方法的名称必须和语句id完全相同,接口方法的返回值和参数和相应的语句相对应。
b.修改映射文件,以便让MyBatis能找到这个映射类。做法就是将映射文件的命名空间改为对应的映射文件的类名。
c.映射类定义和配置好之后,在SqlSession上调用getMapper方法,并传入要获取的Mapper类即可。
利用MyBatis实现分页查询
分页功能,通过mybatis的api实现 selectList("findAll",null,new RowBounds(0,2)) 第一个参数是sql的id,第二个是条件 , 第三是RowBounds(oddset,limit) 构造器 oddset 指定抓取记录的起始行,从0开始 limit 指定抓取记录的数量 查询所有部门信息,每页显示两条,显示出第一页 @Test public void testFindByPage(){ List<Dept> list = sqlSession.selectList("findAll",null,new RowBounds(0,2)); for(Dept dept:list){ System.out.println(dept); } }