快速入门MyBatis——plus

快速入门MyBatis——plus

快速入门MyBatis——plus

首先创建一个springboot项目

1.导入依赖

 <!--mybatis-plus-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.2</version>
        </dependency>
        版本号根据需求选择
注意:mybaits的依赖和mybaits-plus的依赖尽量不要同时使用,不然可能会引起报错

2. 配置连接

spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.url=jdbc:mysql://localhost:3306/mybaits_plus?useSSL=false&useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
基本与前面无异,唯一注意的就是如果数据库是8.0以上,需要加时区错误serverTimezone=GMT%2B8
  1. 编写一个测试数据库**
CREATE TABLE user
(
	id BIGINT(20) NOT NULL COMMENT '主键ID',
	name VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',
	age INT(11) NULL DEFAULT NULL COMMENT '年龄',
	email VARCHAR(50) NULL DEFAULT NULL COMMENT '邮箱',
	PRIMARY KEY (id)
);

4. 编写实体类


@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName(value = "s_student")//默认将类名作为表明,当类名不一的时候就可以用
public class Student {
    @TableId(value = "id",type = IdType.AUTO)//(只能用于主键)如果这里id与数据库不一样,可以通过这个注解指定,type = IdType.AUTO后面在说
    private int id;
    private String sn;
    @TableField(value = "name")//指定字段名(与数据库不一样的话)所有字段都可以用除id字段以外
    private String name;
    private int clazz_id;
    private String sex;
    private String qq;
    private String photo;
    private String mailbox;
    private String address;

    @TableField(exist = false)//不映射数据库表中的任何字段
    private String aa;
}

5.创建mapper层

@Repository/声明这个是持久层
public interface UserMapper extends BaseMapper<User> {
这里与传统不同是,现在就不需要写mapper.xml文件了,只需要继承BaseMapper类,里面自带了CRUD方法,泛型写上对应的实体类就行了
}

6.在启动类上加注解

//扫描mapper文件夹(必须要)
@MapperScan("com.wd.mapper")
@SpringBootApplication
public class MybaisPlusApplication {

    public static void main(String[] args) {
        SpringApplication.run(MybaisPlusApplication.class, args);
    }

}

7. 测试查看

   继承了BaseMapper,所有的方法都来自父类,当然也可以自己写一些方法
    @Autowired
    private UserMapper userMapper;
    @Test
    void contextLoads() {
  selectList这个方法参数是Wrapper,是条件构造器,如果没有条件就写null
        List<User> users = userMapper.selectList(null);
        users.forEach(System.out::println);
    }

查看控制台
在这里插入图片描述
查询完成

8. 测试添加

   @Test
    void testInsert(){
        User user=new User();
        user.setName("易小明");
        user.setAge(18);
        user.setEmail("test6@baomidou.com");
        int insert = userMapper.insert(user);
        System.out.println(user);
        mybaits-plus会自动帮我们生成id字段,所以自己测试的时候就可以不用添加id字段
    }

查看控制台
在这里插入图片描述
数据库
在这里插入图片描述
添加成功
但是可以看见我们的id是很长不是我们想要的,这时我们可以在实体类id字段上加@TableId(type = IdType.AUTO)这是一个id的生成策略,AUTO为自增长,当然数据库也要加上自增,不然不行
在这里插入图片描述
再次添加就可以实现自增长了

这里面有很多id的生成策略
public enum rdType{
AUTO(0),//数据库id自增
NONE(1),//未设置主键
INPUT(2),//手动输入
ID_WORKER(3),// 默认的全局唯一id
UUID(4),//全局唯一id uuid
ID_WORKER_STR(5); //ID_WORKER字符串表示法
}

想详细了解其他id生成策略的可以看看这条帖子https://www.cnblogs.com/haoxinyue/p/5208136.html

8. 测试修改

  @Test
    void testUpdate(){
        User user=new User();
        user.setId(1386945580548526081L);
        user.setName("易小明最可爱啦");
        int update = userMapper.updateById(user);
        注意:updateById他的参数是一个对象
    }

查看控制台
在这里插入图片描述
他会通过调节自动拼接sql,不需要手动去加
在这里插入图片描述
在这里插入图片描述

修改完成

至此,快速入门就算完成了

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值