SpringBoot整合MybatisPlus基础教程

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注解。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值