快速入门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
- 编写一个测试数据库**
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,不需要手动去加
修改完成
至此,快速入门就算完成了