介绍

基本上,数据库设置涉及几个步骤,然后才能在应用程序中通过已配置的数据源使用它。 在实际项目实施中,这实际上是必需的。 但是,在某些情况下,我们只需要为某些事情完成POC,而整个数据库设置工作仍然是必须的。 同样,对于单元测试,理想的是在数据库中拥有我们自己的记录集,使其独立,而不受部署环境中数据更改的影响。 对于此类用例,内存数据库是理想的解决方案。

内存数据库在应用程序启动时创建,而数据库在应用程序停止时销毁。

Spring Boot轻松集成了H2数据库。 因此,您可以轻松,快速地在真实数据库和内存数据库之间切换。

注意,H2 InMemory数据库是用Java编写的关系DBMS。

让我们看一下快速演示。

实作

让我们从Spring initializr生成Spring Boot项目。 确保添加Web,JPA,H2和DevTools依赖关系,如下所示。

让我们看一下生成的pom文件。

pom.xml

<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.jcombat</groupId><artifactId>h2demo</artifactId><version>0.0.1-SNAPSHOT</version><packaging>jar</packaging><name>h2demo</name><description>Demo project for Spring Boot</description><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.0.RELEASE</version><relativePath /> <!-- lookup parent from repository --></parent><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding><java.version>1.8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><scope>runtime</scope></dependency><dependency><groupId>com.h2database</groupId><artifactId>h2</artifactId><scope>runtime</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>

我们还注意到application.properties文件生成为–

application.properties

# H2
spring.h2.console.enabled=true
spring.h2.console.path=/h2# Datasource
spring.datasource.url=jdbc:h2:mem:testdb
spring.datasource.username=sa
spring.datasource.password=
spring.datasource.driver-class-name=org.h2.Driver

属性spring.h2.console.enabled = true启用位于http:// localhost:8080 / h2的Web控制台

单击“连接”,然后进入页面,在该页面中可以看到数据库中的可用表。

您可能想知道,如何创建Student表。 神奇之处在于data.sql位于src / main / resources。 只需确保您在data.sql文件中具有插入语句,如下所述–

data.sql

insert into STUDENT
values(10001,'Ajay', 'AAA1');insert into STUDENT
values(10002,'Ajit', 'AAA2');

Spring Boot自动配置检查data.sql文件中的值,并为您做必要的事情,即创建STUDENT表并执行insert语句。 聪明!

让我们检查一下如何处理这些学生记录。

为此,让我们现在创建Student实体类。

学生.java

package com.jcombat.entity;import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;@Entity
public class Student {@Id@GeneratedValueprivate Long id;private String name;private String section;public Student() {}public Student(Long id, String name, String section) {this.id = id;this.name = name;this.section = section;}public Long getId() {return id;}public void setId(Long id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getSection() {return section;}public void setSection(String section) {this.section = section;}}

要访问数据库,让我们编写一个简单的JPA接口,该接口提供执行基本DB操作所需的帮助程序功能。

StudentRepository.java

package com.jcombat.repository;import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;import com.jcombat.entity.Student;@Repository
public interface StudentRepository extends JpaRepository<Student, Long> {}

现在让我们使用Command Line Runner定制Spring Boot入口点类,以便我们能够从命令行执行Spring Boot应用程序。

package com.jcombat.h2demo;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.domain.EntityScan;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;import com.jcombat.repository.StudentRepository;@SpringBootApplication
@EntityScan("com.jcombat.entity")
@EnableJpaRepositories("com.jcombat.repository")
public class H2demoApplication implements CommandLineRunner {// mvn spring-boot:runprivate Logger LOG = LoggerFactory.getLogger("H2demoApplication");StudentRepository studentRepository;@Autowiredpublic H2demoApplication(StudentRepository studentRepository) {this.studentRepository = studentRepository;}public static void main(String[] args) {SpringApplication.run(H2demoApplication.class, args);}@Overridepublic void run(String... args) throws Exception {LOG.info("Student count in DB: {}", studentRepository.count());}
}

执行应用程序

要运行该应用程序,您可以直接从Eclipse IDE进行操作,也可以通过以下命令从命令行进行操作–

mvn spring-boot:run

执行后,我们会在控制台上看到以下输出–

下载源代码

翻译自: https://www.javacodegeeks.com/2018/11/understandin-inmemory-database-spring.html

通过Spring Boot了解H2 InMemory数据库相关推荐

  1. spring_通过Spring Boot了解H2 InMemory数据库

    spring 介绍 基本上,数据库设置涉及几个步骤,然后才能在应用程序中通过已配置的数据源使用它. 实际上,这在实际项目实施中是必需的. 但是,在某些情况下,我们只需要为某件事完成POC,并且整个数据 ...

  2. inmemory_通过Spring Boot了解H2 InMemory数据库

    inmemory 介绍 基本上,数据库设置涉及几个步骤,然后才能在应用程序中通过已配置的数据源使用它. 在实际项目实施中,这实际上是必需的. 但是,在某些情况下,我们只需要为某件事完成POC,并且整个 ...

  3. Spring Boot + BeetlSQL + H2数据库项目整合

    Spring Boot + BeetlSQL + H2数据库项目整合 这个项目是一个大佬给的,目的是看我的自学能力和基础知识的牢固程度,要求如下: 底层架构采用springboot 前端技术使用lay ...

  4. 在Spring Boot使用H2内存数据库

    文章目录 添加依赖配置 数据库配置 添加初始数据 访问H2数据库 在Spring Boot使用H2内存数据库 在之前的文章中我们有提到在Spring Boot中使用H2内存数据库方便开发和测试.本文我 ...

  5. Spring Boot中使用PostgreSQL数据库

    在如今的关系型数据库中,有两个开源产品是你必须知道的.其中一个是MySQL,相信关注我的小伙伴们一定都不陌生,因为之前的Spring Boot关于关系型数据库的所有例子都是对MySQL来介绍的.而今天 ...

  6. Spring Boot学习总结(27)—— Spring Boot中两个数据库迁移工具Liquibase和Flyway的比较

    前言 当您需要使用Java创建Web应用程序或API时,可以使用RESTful,SOAP或GraphQL.无论您是查看同步HTTP,异步还是反应式,队列中的消息或来自Kafka的事件,都很难超越Spr ...

  7. Spring Boot整合H2内存数据库配置及常见问题处理

    文章目录 H2 数据库简介 内存数据库配置与控制台连接 在内存中创建表以及插入数据 SpringBoot整合H2内存数据查询 常见问题及解决 问题1: Database "mem:XXX&q ...

  8. Spring Boot中使用时序数据库InfluxDB

    除了最常用的关系数据库和缓存之外,之前我们已经介绍了在Spring Boot中如何配置和使用MongoDB.LDAP这些存储的案例.接下来,我们继续介绍另一种特殊的数据库:时序数据库InfluxDB在 ...

  9. Spring Boot中使用MongoDB数据库

    MongoDB简介 MongoDB是一个基于分布式文件存储的数据库,它是一个介于关系数据库和非关系数据库之间的产品,其主要目标是在键/值存储方式(提供了高性能和高度伸缩性)和传统的RDBMS系统(具有 ...

最新文章

  1. ubuntu 10.04 安装eclipse及其中文语言包
  2. java web项目使用log4j的使用笔记
  3. python中返回上一步操作的代码_Pycharm代码跳转后退回操作详解
  4. boost::pfr模块编写自己的 io-manipulator 进行打印的测试程序
  5. MySQL为其他用户创建数据库_MYSQL添加新用户 MYSQL为用户创建数据库 MYSQL为新用户分配权限...
  6. linux删除、读取文件原理
  7. mysql 5.7 not null_mysql5.7基础 select...where...is not null 查找不为NULL的内容
  8. linux路由信息预览为空,route - 显示并设置Linux中静态路由表
  9. html语言怎样设置密码类型,html – 在使用contenteditable div时模仿密码类型输入
  10. postgre sql 括字段_【技术干货】30个最适合初学者的SQL查询
  11. eclipse调试linux内核,Ubuntu下使用Eclipse+CDT+UML调试linux内核
  12. python中if __name__ == __main__:用法解析
  13. 修改高通IPQ4019/4018的flash的分区
  14. CentOS使用DNF配置
  15. 2022年前端技术发展趋势
  16. Sorting 2D Vector in C++ | Set 2 (In descending order by row and column)
  17. 华为鸿蒙杀毒,华为鸿蒙系统
  18. 三八节礼物推荐,不能错过的四款数码好物推荐
  19. Hadoop学习笔记(四)HDFS部分下
  20. docker以及docker-compose 使用加速器部署

热门文章

  1. 【矩阵乘法】沼泽鳄鱼(ssl 2511)
  2. Hadoop生态Flume(一)介绍
  3. Java Agent的隔离实现以及卸载时一些坑
  4. springboot项目不加端口号也可以访问项目的方法
  5. 使用layui弹框实现添加时,当添加成功之后如何进行关闭当前窗口刷新父页面的数据
  6. 安装windows 10操作系统
  7. 最新版Intellij IDEA视频教程 20170814
  8. 毕业设计word 表格标题 图表标题
  9. alertmanager 告警恢复_Prometheus配置企业微信告警
  10. unity 3d shaderlab 开发实战详解_vue实战开发011:使用router-view嵌套路由详解