使用idea快速创建一个springboot工程项目
勾选以下几个依赖

pom.xml文件内容如下:这里采用MyBatis-Plus(增强版的Mybatis)框架作为持久层
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.7.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.ssymon.test</groupId>
<artifactId>h2demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>h2demo</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<!--持久层框架-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.3.1.tmp</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
创建数据库Schema和Data脚本文件:schema.sql,data.sql内容如下
--schema.sql
CREATE TABLE IF NOT EXISTS student
(
id BIGINT(20) NOT NULL COMMENT '主键ID',
name VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',
age INT(11) NULL DEFAULT NULL COMMENT '年龄',
gender INT(1) NULL DEFAULT 1 COMMENT '性别:1-男,0-女',
PRIMARY KEY (id)
);
--data.sql
DELETE FROM student;
INSERT INTO student (id, name, age, gender) VALUES
(1, '张三', 11, 1),
(2, '李四', 12, 0),
(3, '王二', 13, 1),
(4, '麻子', 14, 0),
(5, '胡歌', 18, 1);
application.properties配置文件内容如下
# DataSource Config
spring.datasource.driver-class-name=org.h2.Driver
spring.datasource.url=jdbc:h2:D:/symon/project/db/mptest;
spring.datasource.username=symon
spring.datasource.password=123456
# 指定Schema (DDL)脚本
spring.datasource.schema=classpath:db/schema.sql
# 指定Data (DML)脚本
spring.datasource.data=classpath:db/data.sql
# 指定schema要使用的Platform
spring.datasource.platform=h2
# 是否启用h2控制台
spring.h2.console.enabled=true
# 配置h2控制台访问地址,http://localhost:8080/h2
spring.h2.console.path=/h2
启动项目之后,访问http://localhost:8080/h2即可访问h2控制台
输入用户名和密码登录即可,点击STUDENT表,然后点击Run即可查询
新建实体类Student
@Data
public class Student {
private Long id;
private String name;
private Integer age;
private Integer gender;
}
新建Mapper类,这里继承的是MyBatis-Plus封装的通用 CRUD接口
public interface StudentMapper extends BaseMapper<Student> {
}
在SpringBoot启动类中添加@MapperScan注解,来扫描mapper文件夹
@SpringBootApplication
@MapperScan("com.ssymon.test.h2demo.dao")
public class H2demoApplication {
public static void main(String[] args) {
SpringApplication.run(H2demoApplication.class, args);
}
}
在测试类中编写代码,进行测试
@SpringBootTest
class H2demoApplicationTests {
@Autowired
private StudentMapper studentMapper;
@Test
public void testSelect() {
System.out.println("------ test start ------");
List<Student> userList = studentMapper.selectList(null);
for (Student student : userList) {
System.out.println(student);
}
System.out.println("------ test end ------");
}
@Test
void contextLoads() {
}
}
执行测试代码,控制台输出:
------ test start ------
Student(id=1, name=张三, age=11, gender=1)
Student(id=2, name=李四, age=12, gender=0)
Student(id=3, name=王二, age=13, gender=1)
Student(id=4, name=麻子, age=14, gender=0)
Student(id=5, name=胡歌, age=18, gender=1)
------ test end ------
结语:
通过以上几个简单的步骤,SpringBoot整合H2数据库就结束了!另外我们可以发现,在集成MyBatis-Plus
之后,我们连 XML 映射文件都不用编写就实现了 Student表的 CRUD 功能,真香啊!
既然MyBatis-Plus这么香,那么下篇文章就来学习一下SpringBoot整合MyBatis-Plus。