mybatis-plus入门

mybatis-plus是一个增强mybatis功能的框架,简化了数据库操作。本文介绍了mybatis-plus的使用,包括自动插入、条件构造器、Iservice接口、乐观锁和分页查询,并探讨了Mapper接口和服务接口的区别。同时提到了性能分析插件和代码生成器,帮助提升开发效率。
摘要由CSDN通过智能技术生成

定义

一套完美兼容并增强mybatis的框架,mybatis配置的代码,在mybatis-plus中依旧生效

项目开发中,只需要导入mybatis-plus依赖就可以 

mybatis-plus已经自动配置好sql语句,只要使用约定好的java代码,就可以操作数据库 

使用

public interface UserMapper extends BaseMapper<User>

让接口直接继承mybatis-plus提供的类

测试类直接调用

package com.itheima.mp.mapper;

import com.itheima.mp.domain.po.User;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.time.LocalDateTime;
import java.util.List;

@SpringBootTest
class UserMapperTest {

    @Autowired
    private UserMapper userMapper;

    @Test
    void testInsert() {
        User user = new User();
        user.setId(5L);
        user.setUsername("Lucy");
        user.setPassword("123");
        user.setPhone("18688990011");
        user.setBalance(200);
        user.setInfo("{\"age\": 24, \"intro\": \"英文老师\", \"gender\": \"female\"}");
        user.setCreateTime(LocalDateTime.now());
        user.setUpdateTime(LocalDateTime.now());
        userMapper.insert(user);
    }

    @Test
    void testSelectById() {
        User user = userMapper.selectById(5L);
        System.out.println("user = " + user);
    }


    @Test
    void testQueryByIds() {
        List<User> users = userMapper.selectBatchIds(List.of(1L, 2L, 3L, 4L));
        users.forEach(System.out::println);
    }

    @Test
    void testUpdateById() {
        User user = new User();
        user.setId(5L);
        user.setBalance(20000);
        userMapper.updateById(user);
    }

    @Test
    void testDeleteUser() {
        userMapper.deleteById(5L);
    }
}

javabean和表映射

@TableName(value = "user", autoResultMap = true) 是一个注解,通常用在MyBatis-Plus或类似的ORM框架中。这个注解用来指定一个Java类与数据库中的哪个表对应。

  • value = "user":这部分指定了数据库中的表名,即这个Java类对应的数据库表是user
  • autoResultMap = true:这部分是一个可选参数,当设置为true时,MyBatis-Plus会自动生成对应的ResultMap。ResultMap是MyBatis中用来映射数据库查询结果到Java对象的工具。设置为true可以简化配置,因为框架会自动为你处理这部分的映射。
@TableId(value="id",type = IdType.AUTO) 用来定义主键字段名称

@TableId(type = IdType.AUTO)自增长主键,必须上这个注解

@TableId(type = IdType.ID_WORKER)全局唯一id
public enum IdType {
    AUTO(0), //自增
    NONE(1), //未设置主键
    INPUT(2), //手动输入
    ID_WORKER(3),// 默认全局id
    UUID(4),// 全局唯一id uuid
    ID_WORKER_STR(5); //截取字符串

进入idtype内查看源码,选择策略

 @TableField("username")用来定义普通字段名称

bean数据名称和表字段名称对应,就不需要加这些注解,is开头的字段名除外,关键字要用'字段名'转义字符处理

更多注解功能,查阅官网

自动插入

数据库设置

代码插入

//字段  字段添加填充内容
@TableField(fill = FieldFill.INSERT)//value = ("create_time"),
private Date createTime;
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime;
@Slf4j//日志
@Component//丢到springboot里   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值