日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

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

發布時間:2023/12/3 javascript 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 inmemory_通过Spring Boot了解H2 InMemory数据库 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

inmemory

介紹

基本上,數據庫設置涉及幾個步驟,然后才能在應用程序中通過已配置的數據源使用它。 在實際項目實施中,這實際上是必需的。 但是,在某些情況下,我們只需要為某件事完成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

inmemory

總結

以上是生活随笔為你收集整理的inmemory_通过Spring Boot了解H2 InMemory数据库的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。