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

inmemory

介绍

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

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

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

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

让我们看一下快速演示。

实作

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

H2内存数据库

让我们看一下生成的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控制台

H2内存数据库

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

H2内存数据库

您可能想知道,如何创建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

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

下载源代码

H2内存数据库

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

inmemory

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/332830.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql 查询分组平均数_9、mysql分组查询-----group by 和 having

举例说明&#xff1a;有 Store_Information表之前我们根据这个表&#xff0c;用函数可以算出sales的总和&#xff0c;平均数等如果现在我们需要算出每一间店(store_name)的销售总额(sales)呢&#xff1f;比如&#xff1a;1、los angeles 销售额加起来是 18000san diego…

macOS彻底卸载/删除Microsoft相关的程序

cd /Library/Application\ Support/ # 可以将目录Microsoft整个删除 sudo rm -rf Microsoft # 如果要单独删除微软的自动更新程序&#xff0c;可以进入 cd Microsoft/MAU2.0 # 删除程序文件Microsoft AutoUpdate.app sudo rm -rf Microsoft\ AutoUpdate.app # 进入~/Library/Pr…

java 字符串文字筛选_重新开始Java的原始字符串文字讨论

java 字符串文字筛选在2018年12月宣布 将从JDK 12中删除原始字符串文字 。 现在&#xff0c;在新的一年中&#xff0c;与Java中原始字符串文字的设计有关的讨论又开始了。 在琥珀色专家OpenJDK邮件列表上的“ 原始字符串文字-重新开始讨论 ”一文中 &#xff0c;Brian Goetz参…

mysql event 日志_MySQL Event计划任务刷慢日志

前言最近在尝试一个日志系统graylog来收集mysql的慢查询日志提&#xff0c;供后续的分析、监控和报警等。测试步骤已经到日志已成功收集到graylog&#xff0c;测试时需要刷一些慢查询日志出来。为了刷比较多的日志和不对测试环境造成较大的影响&#xff0c;想到了使用mysql的sl…

aws lambda_API网关和AWS Lambda进行身份验证

aws lambda当Foreach最初踏上微服务之路时&#xff0c;我们并没有真正构建微服务。 我们以为我们做到了&#xff0c;但是我们所有的服务中总存在一些逻辑。 当然&#xff0c;每个服务实际上应该只专注于自己的任务&#xff0c;而不应该专注于属于另一个微服务的事物。 我们这方…

refreshtoken用mysql_微信access_token和refresh_token保存于redis

此处以保存用户授权access_token为例&#xff0c;接口调用access_token可在项目启动时进行缓存。部分代码如下&#xff1a;Autowiredprivate RedisTemplate redisTemplate;Value("${myapp.redisWxUserAccessToken}")private String redisWxUserAccessToken;// 获取pu…

JDBC的基本使用

文章目录概念基本使用步骤详解各个对象DriverManager注册驱动获取数据库连接Connection获取执行 SQL 语句的对象事务管理Statement执行 SQL 语句ResultSetPreparedstatement概念 Java DataBase Connectivity Java 数据库连接&#xff0c;即使用 Java 语言操作数据库 JDBC本质…

sqlrelay mysql_php+sqlrelay+mysql实现连接池及读写负载均衡

phpsqlrelaymysql实现连接池及读写负载均衡上一篇 /下一篇 2008-04-02 18:25:19/ 个人分类&#xff1a;MySQL作者&#xff1a;ziqiusqlrelay.jpg(20.33 KB)2007-8-31 14:26在大型的web应用中数据库经常成为并发访问的一个瓶颈&#xff0c;为了有效的解决并发访问的瓶颈&#x…

maven 文件上传下载_使用Maven将文件上传和下载到S3

maven 文件上传下载多年来&#xff0c;我已经看到许多团队以许多不同的方式使用Maven。 Maven可用于许多ci / cd任务&#xff0c;而无需使用额外的管道代码&#xff0c;或者可用于在运行某些测试之前准备开发环境。 通常&#xff0c;它是一种方便的工具&#xff0c;在Java团队…

JDBC的事务管理

文章目录事务定义操作步骤示例代码事务定义 一个包含多个步骤的业务操作。如果这个业务操作被事务管理&#xff0c;则这多个步骤要么同时成功&#xff0c;要么同时失败。 操作步骤 使用 Connection 对象来管理事务。 1.开启事务 2.提交事务 3.回滚事务 开启事务: setAutoC…

s71200模拟量输入输出_模拟用户输入并检查输出的简单方法

s71200模拟量输入输出最近&#xff0c;我的一些学生向我询问了赫尔辛基大学MOOC提供的单元测试的机制&#xff0c;我检查了它们的实现&#xff0c;并认为这对于初学者了解实际发生的情况是有帮助的&#xff0c;因此在此发表了这篇小文章。 我们将以“机场”项目为例&#xff0…

mysql设计一个简单的系统_一个简单数据库设计例子

一个曾经做过的简单的管理系统中数据库设计的例子,包括设计表、ER图、建模、脚本. 项目信息 Project Name: Book Manager System DB: MySQL5.5 DB Name: db_library Tables: 1). tb_book_info 2). tb_user 3). tb_admin_info 4). tb_borrow_return 5). tb_boo一个曾经做过的简单…

数据库连接池_DataSource_数据源(简单介绍C3P0和Druid)

文章目录概念好处实现C3P0基本使用配置文件druid下载 jar 包配置文件演示代码定义工具类示例代码概念 数据库连接池其实就是一个容器&#xff0c;而这个容器其实就是一个集合&#xff0c;这个集合存放着多个数据库连接对象。 系统在初始化的时候&#xff0c;将创建一定数量的数…

graal java_使用SparkJava和Graal的本机微服务

graal java使用SparkJava编写的微服务只是使用标准Java库的普通Java代码。 没有注释魔术&#xff0c;只有代码。 这种简单的编程风格的优点在于&#xff0c;它很简单。 非常简单&#xff0c;以至于Graal本机编译器只需编译就不会闪烁 &#xff0c;这对于例如Spring之类的更复杂…

python消息订阅_python实现发布订阅

订阅者&#xff1a;import redisrc redis.StrictRedis(host‘127.0.0.1‘, port‘6379‘, db0)ps rc.pubsub()ps.subscribe(‘lbky‘) # 从lbky订阅消息for item in ps.listen(): # 监听状态&#xff1a;有消息发布了就拿过来print(item)if item[‘type‘] ‘message‘:prin…

使用JDBC连接数据库时,SQL语句中提示:Unable to resolve table...(原因:数据源未配置)

文章目录方法一、添加数据源方法二、输入全限定表名在 IDEA 中的 Java 代码中写 SQL 语句时&#xff0c;出现如下图所示的错误提示&#xff1a;方法一、添加数据源 要解决上面红色警告的问题&#xff0c;只需要添加数据源就可以解决。 方法二、输入全限定表名 前提&#xff1…

测试反模式冰激凌模式的不足_单元测试反模式,完整列表

测试反模式冰激凌模式的不足我前段时间写过有关OOP中的反模式的文章 。 现在该写单元测试反模式了&#xff0c;因为它们也存在&#xff0c;并且有很多。 我将尝试在列表中包括我知道的每个示例。 如果您认识其他任何人&#xff0c;请通过请求请求将其添加&#xff0c;或在下面发…

mysql导入三个基本表_mysql 基础导入导出

导入导出mysqldump导出&#xff1a;mysqldump -u root -p --databases 数据库1 数据库2 > xxx.sql导入&#xff1a;系统命令行&#xff1a; MySQL -u用户名 -p密码 常见选项&#xff1a;--all-databases, -A&#xff1a; 备份所有数据库--databases, -B&#xff1a; 用于备份…

Java代码中方法的特殊修饰符/修饰词/关键字

文章目录nativesynchronizednative 用该修饰符定义的方法在类中没有实现&#xff0c;而大多数情况下该方法的实现是用C、C编写的。 synchronized 多线程的支持。用该修饰符定义的方法被调用时&#xff0c;没有其它线程能够调用该方法&#xff0c;其它的 synchronized 方法也…

aws dynamodb_带有AWS DynamoDB的React式Spring Webflux

aws dynamodbAWS已经发布了Java版本2的AWS开发工具包 &#xff0c;该开发工具包现在支持针对不同AWS服务的API调用的非阻塞IO。 在本文中&#xff0c;我将探讨如何使用AWS开发工具包2.x的DynamoDB API以及如何使用Spring Webflux堆栈公开响应式端点-这种方式&#xff0c;应用程…