mybatis-plus实体类

@Data
@TableName(value = "tb_employee")//指定表名
public class Employee {
    //value与数据库主键列名一致,若实体类属性名与表主键列名一致可省略value
    @TableId(value = "id",type = IdType.AUTO)//指定自增策略
    private Integer id;
    //若没有开启驼峰命名,或者表中列名不符合驼峰规则,可通过该注解指定数据库表中的列名,exist标明数据表中有没有对应列
    @TableField(value = "last_name",exist = true)
    private String lastName;
    private String email;
    private Integer gender;
    private Integer age;
}

引用:mybatis-plus介绍

mybatis-plus是基于mybatis,相对于mybatis,他有许多特性是比较好用的,比如分页查询、表字段自动转换为实体类属性等,使用mybatis-plus与Spring Data JPA有点相似的地方,个人觉得mybatis-plus的分页比JPA的分页好用。其实在mybatis-plus官网上已经有很详细的教程了,在这里写博客也是为了自己能够更好的整理思路。先上一下官网基于springboot教程地址:https://baomidou.oschina.io/mybatis-plus-doc/#/spring-boot

1.添加pom引用

maven的引用很简单,官方已经给出starter,不需要我们考虑它的依赖关系了,此处使用的是2.3版本。

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

2.配置

官方已经提供了基于springboot的配置,将其拷贝过来放在application.yml中即可使用,此处只是将官方部分的配置删减过一些。其中column-underline: true特别好用,会自动将下划线格式的表字段,转换为以驼峰格式命名的属性。

mybatis-plus:
  global-config:
    db-config:
      id-type: auto
      field-strategy: not_empty
      #驼峰下划线转换
      column-underline: true
      #逻辑删除配置
      logic-delete-value: 0
      logic-not-delete-value: 1
      db-type: mysql
    refresh: false
  configuration:
    map-underscore-to-camel-case: true
    cache-enabled: false

3.使用

1.创建实体类,创建实体类与JPA特别相似,其中@TableName注解是为了指定此实体类对应数据库的哪一张表;@TableId指定的是主键,type属性指定的是该主键自增的方式,AUTO代表自增,UUID代表使用UUID增加主键;还有一个注解@TableFiled,此注解主要用在非主键实体属性上,下面是官方给出的此注解所有属性。

描述
value字段值(驼峰命名方式,该值可无)
update预处理 set 字段自定义注入
condition预处理 WHERE 实体条件自定义运算规则
el详看注释说明
exist是否为数据库表字段( 默认 true 存在,false 不存在 )
strategy字段验证 ( 默认 非 null 判断,查看com.baomidou.mybatisplus.enums.FieldStrategy )
fill字段填充标记 ( FieldFill, 配合自动填充使用 )

生成一个实体类实例

@TableName("t_patrol_task")
public class PatrolTaskEntity {
 
    @TableId(value = "id",type = IdType.AUTO)
    private Integer id;
 
    private Integer jobId;
 
   Getter…
   Setter….
}

2.创建mapper,与JPA有相像之处。使用@Mapper为了把mapper这个DAO交給Spring管理,且可以不再写mapper映射文件;继承BaseMapper可以方便使用mybatis-plus方法,泛型需要写对用的实体类。此处直接使用slelect * from,mybatis-plus会根据实体类自动驼峰转下划线映射到表的字段中。

@Mapper
public interface PatrolTaskMapper extends BaseMapper<PatrolTaskEntity> {
 
    @Select("select * from t_patrol_task where id = #{id} and deleted_at is null")
    PatrolTaskEntity queryByIdAndDeletedAtIsNull(@Param(“id”) Integer id);
}

4.条件构造器

1.查询单条数据,非主键查询,只要在一个实体内写入属性,然后再用mybatis-plus自带的selectOne()方法即可查询(注意:查询的限制条件必须此条数据是唯一的,不然查询后会报错)。个人觉得此种查询使用不便,不如直接使用nativeSql进行查询来的利索。

PatrolJobLogEntity jobLogEntity = new PatrolJobLogEntity();
jobLogEntity.setJobId(12);
jobLogEntity.setTaskFinished(30);
patrolJobLogMapper.selectOne(jobLogEntity);

2.查询数量,含有拼接方式查询。使用mybatis-plus条件查询需要使用到EntityWrapper构造器,它能添加查询的条件,如:.eq(“job_id”,13)表示查询job_id=13的记录,isNull(“deleted_at”)表示deleted_at必须为null(注意:此处查询的条件是使用的是数据库表中的字段名称)。

EntityWrapper<PatrolTaskEntity> wrapper = new EntityWrapper<>().eq("job_id",13).isNull("deleted_at");
List<PatrolTaskEntity> tasks = patrolTaskMapper.selectCount(wrapper);

3.查询列表,与上面基本相同,只不过此处使用的是mybatis-plus的selectList()方法

EntityWrapper<PatrolTaskEntity> wrapper = new EntityWrapper<>().eq("job_id",13).isNull("deleted_at");
List<PatrolTaskEntity> tasks = patrolTaskMapper.selectList(wrapper);

拼接sql查询方式:

查询方式说明
setSqlSelect设置 SELECT 查询字段
whereWHERE 语句,拼接 + WHERE 条件
andAND 语句,拼接 + AND 字段=值
andNewAND 语句,拼接 + AND (字段=值)
orOR 语句,拼接 + OR 字段=值
orNewOR 语句,拼接 + OR (字段=值)
eq等于=
allEq基于 map 内容等于=
ne不等于<>
gt大于>
ge大于等于>=
lt小于<
le小于等于<=
like模糊查询 LIKE
notLike模糊查询 NOT LIKE
inIN 查询
notInNOT IN 查询
isNullNULL 值查询
isNotNullIS NOT NULL
groupBy分组 GROUP BY
havingHAVING 关键词
orderBy排序 ORDER BY
orderAscASC 排序 ORDER BY
orderDescDESC 排序 ORDER BY
existsEXISTS 条件语句
notExistsNOT EXISTS 条件语句
betweenBETWEEN 条件语句
notBetweenNOT BETWEEN 条件语句
addFilter自由拼接 SQL
last拼接在最后,例如:last(“LIMIT 1”)

5.分页

1.添加配置文件,此处配置文件表示开启mybatis-plus分页功能

@EnableTransactionManagement
@Configuration
public class MybatisPlusConfig {
 
    @Bean
    public PaginationInterceptor paginationInterceptor() {
        return new PaginationInterceptor();
    }
}

2.写查询语句,此出的Pagination必须给出,不然无法完成分页功能。

@Mapper
public interface BannerLogMapper extends BaseMapper<BannerLogEntity> {
 
    @Select("select * from t_pub_banner_logs")
    List<BannerLogEntity> queryLogByPage(Pagination page);
}

3.进行分页查询代码块,只需要将要查询的第几页也页面大小写入到Page对象中。然后进行查询,查询后分页属性(当前页,总页数、总条数), 是经过插件自动回写到传入page对象中。

Page<BannerLogEntity> page = new Page<>(pageNo,pageSize);
List<BannerLogEntity> bannerLogs = bannerLogMapper.queryLogByPage(page);
page.getTotal();
page.getCurrent();
page.getPages();

6.其他

关于mybatis-plus其他功能,代码生成器、性能分析插件、执行分析插件、多数据源处理等可以自行到官网查看学习。

原文链接:https://blog.csdn.net/zc_ad/article/details/83301911

### MyBatis-Plus 实体类继承 `Model` 类遇到的问题及解决方案 当使用 MyBatis-Plus 并尝试让实体类继承自 `com.baomidou.mybatisplus.extension.activerecord.Model<T>` 时,可能会遇到一些问题。如果发现继承无效或无法正常工作,可以考虑以下几个方面来解决问题。 #### 配置依赖版本兼容性 确保项目中的 MyBatis-Plus 版本与其他相关库保持一致且最新。不同版本之间可能存在 API 变更或移除的情况,这可能导致某些特性不再支持。建议查看官方文档确认当前使用的版本是否仍然推荐使用 ActiveRecord 模式[^1]。 #### 正确引入所需模块 为了使 `Model<T>` 能够正常使用,在构建工具(如 Maven 或 Gradle)配置文件中应加入如下依赖: 对于 Maven 用户来说: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-extension</artifactId> <version>${mybatis.plus.version}</version> </dependency> ``` 而对于 Gradle 用户,则应在 build.gradle 文件内添加: ```groovy implementation 'com.baomidou:mybatis-plus-extension:${mybatis.plus.version}' ``` 这里 `${mybatis.plus.version}` 应替换为你实际使用的具体版本号[^4]。 #### 修改实体类定义方式 除了简单地继承 `Model<User>` 外,还需要注意以下几点以确保正确实现: - 使用 `@TableName` 注解指定表名; - 定义字段并提供相应的 Getter 和 Setter 方法; - 如果有主键生成策略或其他特殊需求,可以通过相应注解进行设置; 例如修改后的 `User` 实体类可能看起来像这样: ```java import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.annotation.TableId; import com.baomidou.mybatisplus.annotation.TableName; @TableName("user") public class User extends Model<User> { @TableId(value="id", type= IdType.AUTO) private Long id; @TableField("name") private String name; @TableField("age") private Integer age; @TableField("email") private String email; // Getters and Setters... } ``` 通过上述调整后再次运行程序测试效果如何。另外值得注意的是,虽然早期版本确实存在过此类问题,但在较新的发行版里已经得到了修复和支持改进。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值