问题:在mybatis generator生成代码后,在此基础上加了其他自定义代码后,数据库有改动,但是不想手写实体类和dao层。
项目结构:红色部分为新增部分

解决:SubTblPayDao 继承 TblPayDao
package com.mashibing.lcnpay.dao;
import com.mashibing.lcnpay.entity.TblPay;
@Mapper
public interface SubTblPayDao extends TblPayDao {
TblPay selectByName(String name);
}
SubTblPayDao.xml 下面第二三个红色方框指向父类的dao

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.mashibing.lcnpay.dao.SubTblPayDao">
<select id="selectByName" parameterType="java.lang.Integer"
resultMap="com.mashibing.lcnpay.dao.TblPayDao.BaseResultMap">
select
<include refid="com.mashibing.lcnpay.dao.TblPayDao.Base_Column_List"/>
from tbl_pay
where id = #{id,jdbcType=INTEGER}
</select>
</mapper>
单元测试一下:

在使用MyBatisGenerator生成代码后,当数据库表结构发生变化时,通常需要手动更新实体类和DAO层。为避免手动操作,本文介绍了通过让子类SubTblPayDao继承TblPayDao实现自动同步的策略。在SubTblPayDao中添加了一个新的selectByName方法,并在XML映射文件中引用父类的BaseResultMap,实现了功能扩展。通过单元测试验证了这种方法的有效性。

5503

被折叠的 条评论
为什么被折叠?



