Mybatis plus
概念
使用Mybatis时,大的问题是,要写大量的重复SQL语句在xml文件中,除了特殊的业务逻辑SQL语句之外,还有大量结构类似的增删改查SQL。而且,当数据库表结构改动时,对应的所有SQL以及实体类都需要更改。这大量增 加了程序员的负担。避免重复书写CRUD映射的框架有两个
- 通用mybatis(tk mybatis)
- mybatis plus,通能更加强大
依赖
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.3.2</version>
</dependency>
注意:mybatisplus集成,引入MyBatis-Plus 之后请不要再次引入 MyBatis 以及 MyBatis-Spring,以避免因版本差异导致的问题
实体类
MyBatisPlus提供了一些注解供我们在实体类和表信息出现不对应的时候使用。通过使用注解完成逻辑上匹配。
注解名称 | 说明 |
---|---|
@TableName | 实体类的类名和数据库表名不一致 |
@TableId | 实体类的主键名称和表中主键名称不一致 |
@TableField | 实体类中的成员名称和表中字段名称不一致 |
@AllArgsConstructor
@NoArgsConstructor
@ToString
@TableName("tab_category")
public class TabCategory implements Serializable {
@TableId(type = IdType.AUTO)
private Integer cid;
private String cname;
public Integer getCid() {
return cid;
}
public void setCid(Integer cid) {
this.cid = cid;
}
public String getCname() {
return cname;
}
public void setCname(String cname) {
this.cname = cname == null ? null : cname.trim();
}
}
mybatis plus注解策略配置
如果mysql自增主键注解策略设置如下
@TableId(type = IdType.AUTO)
private Long id;
默认主键策略
/** * 采用雪花算法生成全局唯一主键 **/
ASSIGN_ID(3)
排除实体类中非表字段:
使用 @TableField(exist = false) 注解
Mapper持久层
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
@Repository
public interface TabCategoryMapper extends BaseMapper<TabCategory> {
}
必须继承 MybatisPlus提供的BaseMapper类,以及使用需要操作的bean类作为泛型参数。
启动类
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@MapperScan("com.kaikeba.mapper")
public class SpTravelApplication {
public static void main(String[] args) {
SpringApplication.run(SpTravelApplication.class, args);
}
}
接口扫描使用MybatisPlus的MapperScan注解。