浅谈Mybatis通用Mapper使用方法
对单表进行增删改查是项目中不可避免的需求,Mybatis的通用Mapper插件使这些操作变得简单
添加maven依赖
在对应工程的pom.xml文件中添加
javax.persistence persistence-api 1.0 tk.mybatis mapper 3.1.2
配置拦截器
在mybatis-config.xml文件中添加通用Mapper
继承通用Mapper
publicinterfaceClubMapperextendsMapper{ }
继承了Mapper
泛型(表对象实体类)
实体类需要按照如下规则和数据库表进行转换,注解全部是JPA中的注解,所以我们在maven中添加了它的jar包依赖
- 表名默认使用类名,驼峰转下划线,如UserInfo默认对应的表名为user_info
- 表名可以使用@Table(name="tableName")进行指定,对不符合第一条默认规则的可以通过这种方式指定表名
- 字段默认和@Column一样,都会作为表字段,表字段默认为Java对象的Field名字驼峰转下划线形式
- 可以使用@Column(name="fieldName")指定不符合第3条规则的字段名
- 使用@Transient注解可以忽略字段,添加该注解的字段不会作为表字段使用
- 建议一定是有一个@Id注解作为主键的字段,可以有多个@Id注解的字段作为联合主键
- 默认情况下,实体类中如果不存在包含@Id注解的字段,所有的字段都会作为主键字段进行使用(这种效率极低)
- 实体类可以继承使用
- 由于基本类型,如int作为实体类字段时会有默认值0,而且无法消除,所以实体类中建议不要使用基本类型
Mapper还提供了主键自增的方式
@Id @GeneratedValue(generator="JDBC") @Column(name="id") privateIntegerid;
添加Mapper配置
将继承的Mapper接口添加到mybatis-config.xml文件中
具体使用
publicListqueryList()throwsCcpException { SqlSessionsqlSession=CcpDB.getInstance().getSession(); try { ClubMappermapper=getMapper(sqlSession); TClubtClub=newTClub(); returnmapper.select(tClub); } catch(Exceptione) { CcpLogger.getInstance().error(e,"TClubDAO.queryList,status="+status); thrownewCcpException(CcpErrorCode.ERROR_CLUB_DAO_DB_ERROR,e); } finally { CcpDB.getInstance().closeSession(); } } privateClubMappergetMapper(SqlSessionsqlSession) { returnsqlSession.getMapper(ClubMapper.class); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。