MyBatis-Plus(简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
导入依赖:
com.baomidou mybatis-plus 3.5.2
MP配置需要覆盖MyBatis配置,具体配置查看使用配置 | MyBatis-Plus:
@Bean//MP配置
public SqlSessionFactory mybatisSqlSessionFactory(DataSource dataSource) throws Exception {MybatisSqlSessionFactoryBean factory=new MybatisSqlSessionFactoryBean();factory.setConfiguration(new MybatisConfiguration());factory.setGlobalConfig(new GlobalConfig());factory.setDataSource(dataSource);return factory.getObject();
}
通用 CRUD 封装 BaseMapper 接口,为 MP 启动时自动解析实体表关系映射转换为 MyBatis 内部对象注入容器。
@Mapper
public interface BookMapper extends BaseMapper {}
通用 Service CRUD 封装 IService 接口,进一步封装 CRUD 采用 get 查询单行、list 查询集合、page 分页、remove 删除、save 添加、update 更新前缀命名方式区分 Mapper 层避免混淆。
public interface BookService extends IService {}@Service
public class BookServiceImp extends ServiceImpl implements BookService {}
实体类只需继承 Model 类即可进行强大的 CRUD 操作,需要项目中已注入对应实体的BaseMapper。
@Component
public class Book extends Model {}
@TableName:实体类标注,标识实体类对应的表。
@TableId:属性标注,标识主键属性。
@TableField:属性标注,标识字段属性。
@TableLogic:属性标注,标识逻辑删除属性。
其他注解查看:注解 | MyBatis-Plus
AbstractWrapper:QueryWrapper(LambdaQueryWrapper) 和UpdateWrapper (LambdaUpdateWrapper) 的父类用于生成 sql 的 where 条件, entity 属性也用于生成 sql 的 where 条件。
QueryWrapper:继承自 AbstractWrapper ,自身的内部属性 entity 也用于生成 where 条件
及 LambdaQueryWrapper, 可以通过 new QueryWrapper().lambda() 方法获取。
UpdateWrapper:承自 AbstractWrapper ,自身的内部属性 entity 也用于生成 where 条件
及 LambdaUpdateWrapper, 可以通过 new UpdateWrapper().lambda() 方法获取。
具体构造方法查看:条件构造器 | MyBatis-Plus
MybatisPlusInterceptor:该插件是核心插件,目前代理了 Executor#query、Executor#update 和 StatementHandler#prepare 方法。
目前已有的功能:
@Bean//插件
public MybatisPlusInterceptor mybatisPlusInterceptor(){MybatisPlusInterceptor interceptor=new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;
}
具体插件使用查看:插件主体 | MyBatis-Plus
上一篇:07.C语言文件操作
下一篇:解剖一道有意思的指针题