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);
    }
}

 

转载于:https://www.cnblogs.com/motianjie/p/7846467.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值