Mybatis通用Mapper配置
https://blog.csdn.net/qq1130169218/article/details/71747429
demo 示例
https://github.com/huangzhenshi/mybatis-mapper
注意事项
- 实体类需要按照如下规则和数据库表进行转换,注解全部是JPA中的注解,所以我们在maven中添加了它的jar包依赖
- 表名默认使用类名,驼峰转下划线,如UserInfo默认对应的表名为user_info
- 表名可以使用@Table(name = “tableName”)进行指定,对不符合第一条默认规则的可以通过这种方式指定表名
- 字段默认和@Column一样,都会作为表字段,表字段默认为Java对象的Field名字驼峰转下划线形式
- 可以使用@Column(name = “fieldName”)指定不符合第3条规则的字段名
- 使用@Transient注解可以忽略字段,添加该注解的字段不会作为表字段使用,建议一定是有一个@Id注解作为主键的字段,可以有多个@Id注解的字段作为联合主键
- 默认情况下,实体类中如果不存在包含@Id注解的字段,所有的字段都会作为主键字段进行使用(这种效率极低)
- 实体类可以继承使用
- 由于基本类型,如int作为实体类字段时会有默认值0,而且无法消除,所以实体类中建议不要使用基本类型
API
|
搭建过程
引入依赖
<dependency><groupId>javax.persistence</groupId><artifactId>persistence-api</artifactId><version>1.0</version></dependency><!--通用Mapper--><dependency><groupId>tk.mybatis</groupId><artifactId>mapper</artifactId><version>3.3.9</version></dependency>指定Mapper接口所在包路径
<bean class="tk.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="com.test.IDao"/></bean>标明实体类和表映射关系
@Data@Table(name="user_t")public class User {@Idprivate Long id;private String userName;private String password;private Short age;}接口类集成Mapper和指定实体类
public interface UserDAO extends Mapper<User>{}调用
@Transactionalpublic void saveUser(){User user = new User();user.setUserName("test1736");user.setPassword("qwert");userDAO.insertSelective(user);}