SpringBoot整合H2Database(IDEA)

本文介绍如何使用SpringBoot快速搭建H2数据库项目,并集成MyBatis-Plus实现CRUD操作,无需编写XML映射文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用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。

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值