Spring boot+MyBatis-Plus简单使用

首先引入依赖

    <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.3</version>
        </dependency>

 mybatis-plus是mybatis的增强工具,提高了效率。

持久层只需实现继承BaseMapper接口便可以直接进行操作

public interface RoleMapper extends BaseMapper<TabRole>//需要放入泛型

在BaseMapper接口中我们可以直观的看所实现的功能

    int insert(T entity);

    int deleteById(Serializable id);

    int deleteByMap(@Param("cm") Map<String, Object> columnMap);

    int delete(@Param("ew") Wrapper<T> queryWrapper);

    int deleteBatchIds(@Param("coll") Collection<? extends Serializable> idList);

    int updateById(@Param("et") T entity);

    int update(@Param("et") T entity, @Param("ew") Wrapper<T> updateWrapper);

    T selectById(Serializable id);

    List<T> selectBatchIds(@Param("coll") Collection<? extends Serializable> idList);

    List<T> selectByMap(@Param("cm") Map<String, Object> columnMap);

    T selectOne(@Param("ew") Wrapper<T> queryWrapper);

    Integer selectCount(@Param("ew") Wrapper<T> queryWrapper);

    List<T> selectList(@Param("ew") Wrapper<T> queryWrapper);

    List<Map<String, Object>> selectMaps(@Param("ew") Wrapper<T> queryWrapper);

    List<Object> selectObjs(@Param("ew") Wrapper<T> queryWrapper);

    <E extends IPage<T>> E selectPage(E page, @Param("ew") Wrapper<T> queryWrapper);

    <E extends IPage<Map<String, Object>>> E selectMapsPage(E page, @Param("ew") Wrapper<T> queryWrapper);

 做所有查询时直接调用即可使用(默认是驼峰命名法)

queryWrapper 是查询的条件

  void test() {
        QueryWrapper<TabRole> wrapper = new QueryWrapper<>();
      wrapper.between("role_id", 1, 4);//
        wrapper.like("role_state", "0");
        List list = roleMapper.selectList(wrapper);
        System.out.println(list);
    }

执行sql如下 

 Preparing: SELECT role_id,role_name,role_code,role_desc,role_state,
operator_name,operator_id,
operator_time,insert_time FROM tab_role
 WHERE role_state=0 
AND (role_id BETWEEN ? AND ? OR role_state LIKE ?)

其他调用也十分简单 直接调用关键词即可如更新roleMapper.updateById(role)、删除 roleMapper.deleteById(id);等

 2.实体类注解的的应用

1)主键

主键需要声明@TableId

@TableId(type = IdType.AUTO)
  private Long roleId;

 type有几种类型AUTO-数据库自增,NONE-MP set主键,雪花算法实现,

INPUT-需要开发者手动赋值,ASSIGN_ID-MP分配ID,Long、Integer.String,

ASSIGN_UUID-分配UUID,String

NONE 自动生成主键需要注意 主键数据类型需要将int转换为long,数据库表长度也要改

INPUT 如果没有对主键ID赋值数据库将为0,如果有自增编号+1

2)日期自动填充

实现该功能需要对字段添加注解

  @TableField(fill = FieldFill.INSERT_UPDATE)//更新和插入的时候填充
  private Date operatorTime;
  @TableField(fill =FieldFill.INSERT )
  private Date insertTime;

 配置文件

@Configuration
public class MyConfig implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
        //插入时insertTime字段自动填充当前时间
        this.strictInsertFill(metaObject, "insertTime", Date.class, new Date());
        this.strictInsertFill(metaObject, "operatorTime", Date.class, new Date());
    }

    @Override
    public void updateFill(MetaObject metaObject) {
    //更新时自动填充当前时间
        this.strictUpdateFill(metaObject, "operatorTime", Date.class, new Date());
    }
}

3)分页

运用分页插件的时候也需要配置

 

 

@Configuration
public class MyConfig implements MetaObjectHandler {

    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }
}

 然后调用Page类调用


     Page<TabRole> tabRolePage = new Page<>(page.getPage(),  page.getLimit());
        List<TabRole> list = roleMapper.selectList(null);

 

 

 

 

 

 

 

插件主体(必看!)(since 3.4.0) | MyBatis-Plus (baomidou.com)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring BootMyBatis-Plus是两个流行的Java开发框架。Spring Boot是一个用于简化和加速Java应用程序开发的框架,而MyBatis-Plus是MyBatis的增强版,提供了更多的特性和功能。 使用Spring Boot2和MyBatis-Plus的组合,能够使开发过程更加高效和简便。Spring Boot2已经集成了很多常用的配置和功能,例如自动配置、快速启动器和监控等。这些功能使得开发者可以更加专注于业务逻辑而不用过多关注繁琐的配置。 而MyBatis-Plus提供了一系列强大且易于使用的功能,例如代码生成器、分页查询、逻辑删除和性能优化等。代码生成器能够帮助开发者快速生成数据库表对应的实体类、Mapper接口以及XML映射文件,大大提高了开发效率。分页查询和逻辑删除功能使得数据操作更加方便和灵活。另外,MyBatis-Plus对SQL语句进行了优化,能够提升数据库查询的性能。 使用Spring Boot2和MyBatis-Plus的组合还能够更好地兼容其他常用的开发工具和框架,例如Spring Security和Swagger等。Spring Security提供了安全认证和授权的功能,能够保护应用程序的安全性。Swagger可以生成API文档,并提供了一个用户友好的UI界面,方便开发者进行接口测试和调试。 总之,Spring Boot2和MyBatis-Plus的组合能够提高开发效率、简化配置、优化性能并提供额外的功能。对于Java开发者来说,这是一个非常不错且受欢迎的选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一大条鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值