H2 數據庫使用簡介


博客地址:http://www.moonxy.com

一、前言

H2 是一個用 Java 開發的嵌入式數據庫,它本身只是一個類庫,即只有一個 jar 文件,可以直接嵌入到應用項目中。H2 主要有如下三個用途:

第一個用途,也是最常使用的用途就在於可以同應用程序打包在一起發布,這樣可以非常方便地存儲少量結構化數據。

第二個用途是用於單元測試。啟動速度快,而且可以關閉持久化功能,每一個用例執行完隨即還原到初始狀態。

第三個用途是作為緩存,即當做內存數據庫,作為NoSQL的一個補充。當某些場景下數據模型必須為關系型,可以拿它當Memcached使,作為后端MySQL/Oracle的一個緩沖層,緩存一些不經常變化但需要頻繁訪問的數據,比如字典表、權限表。

二、下載安裝

2.1 下載

h2 數據庫下載地址:http://www.h2database.com/html/main.html 或者 http://www.h2database.com/html/download.html

選擇 "All Platforms" 版本,是一個壓縮包,解壓后即可使用既可用於 Windows 平台,也可用於 Linux 平台。

2.2 H2 目錄結構

h2
 |---bin
 |    |---h2-1.1.116.jar  //H2數據庫的jar包(驅動也在里面)
 |    |---h2.bat  //Windows控制台啟動腳本
 |    |---h2.sh  //Linux控制台啟動腳本
 |    |---h2w.bat  //Windows控制台啟動腳本(不帶黑屏窗口)
 |---docs  //H2數據庫的幫助文檔(內有H2數據庫的使用手冊)
 |---service  //通過wrapper包裝成服務。
 |---src  //H2數據庫的源代碼
 |---build.bat  //windows構建腳本
 |---build.sh  //linux構建腳本

三、管理終端

3.1 啟動

進入H2 的 bin 目錄,如果在 Window 環境下使用,可以運行 h2.bat 或 h2w.bat。區別只是后者是后台靜默運行。

如果你在 Linux 環境下,可運行./h2.sh 文件來啟動數據庫服務。但不建議這樣直接啟動,因為還有一些參數可以設置。可進行如下修改:

1)復制h2.sh為h2_server.sh文件;

2)編輯h2_server.sh,如下:

#!/bin/sh
dir=$(dirname"$0")
java -cp "$dir/h2-1.4.197.jar:$H2DRIVERS:$CLASSPATH" org.h2.tools.Server -tcpAllowOthers -webAllowOthers -webPort 8082 "$@"

3)說明:

org.h2.tools.Server: 以服務器模式啟動

-tcpAllowOthers: 允許遠程機器通過TCP方式訪問

-webAllowOthers: 允許遠程機器通過瀏覽器訪問

-webPort 8082: 默認的訪問端口(8082為未被占用的端口,如果此端口已經被其他端口占用,則改為其他端口)

4)具體的運行方式

chmod修改文件權限;

輸入nohup ./h2_server.sh & 回車。這樣可以后台運行。

nohup 命令可以在你退出賬戶之后繼續運行相應的進程。nohup 就是不掛起的意思(no hang up)。& 表示讓該進程實現后台運行。該命令的一般形式為:

# nohup command &

比如運行了 h2.bat,系統會進入:

或者自己打開瀏覽器,輸入地址:http://localhost:8082 訪問 H2 數據庫的 Web Console。這里就需要說明一下 "~" 這個符號在window操作系統下代表什么意思,在Window操作系統下,"~"這個符號代表的就是當前登錄到操作系統的用戶對應的用戶目錄,與 Linux 系統中的意義相同,代表用戶家目錄。

最上方可以選擇 language,可以進行語言切換。如切換成中文:

點擊藍色字體配置,可以跳轉到配置H2數據庫的另一個頁面,點擊工具,會給你提供一堆對H2數據庫操作的功能,比如:備份、還原、恢復、集群、運行腳本、刪除文件等等。點擊幫助,會提示一些關於 H2 數據庫使用的幫助信息。接下來就是最重要的配置數據庫連接信息,驅動類和 JDBC URL 是默認的,如果你想創建一個新的數據庫,直接修改 jdbc:h2:[輸入你想創建的數據庫文件的路徑],就可以為你自動創建一個新的數據庫(在指定路徑下會創建對應的數據庫文件 xxxx.mv.db),用戶名密碼由用戶自行定義,連接數據庫之前還可以點擊測試連接,測試是否可以正確連接。

如下:

生成的數據庫文件:

點擊連接后可進入管理終端,很類似於 phpMyAdmin 這樣的 Web 管理終端,執行具體的數據庫 SQL 語句:

常用的兩個快捷鍵:

Ctrl+Enter 執行輸入區的 SQL,按 Shift+Enter 執行當前選中的 SQL。

四、應用程序開發

H2數據庫的開發非常簡單,和 MySQL 等沒有太大區別。

4.1 加入 Maven 依賴

<dependency>
  <groupId>com.h2database</groupId>
  <artifactId>h2</artifactId>
  <version>1.4.197</version>
</dependency>

4.2 創建 db.properties

driverClassName=org.h2.Driver
# 此處的寫法是使用嵌入模式鏈接 H2 庫,緊接着那行是使用 Server Mode 用 tcp 連接。區別是前者性能更好,后者可同時供多個客戶端連接。
url=jdbc:h2:F:/software/h2data/h2test
#url=jdbc:h2:tcp://localhost//usr/h2data/h2test=rootpassword=123456

注意:

比如上面創建了 db.properties 文件,然后將其放入項目的 resources 目錄中,此時需要打開項目的 .classpath 文件,加入:<classpathentry kind="src" path="resources"/>

通常 .classpath 文件中均會包含如下設置:

<classpathentry kind="src" path="src"/>

<classpathentry kind="src" path="resources"/>

顯示如下:

關於 .classpath 文件的具體講解,可以參考如下博客文章:

eclipse項目中.classpath文件詳解

4.3 JDBC 連接 H2

可以參考附錄中的博客文章地址,與使用其他的數據庫操作相同。

五、H2 連接方式

H2 支持以下三種連接模式:

1)嵌入式模式(使用 JDBC 的本地連接)

2)服務器模式(使用 JDBC 或 ODBC 在 TCP/IP 上的遠程連接)

3)混合模式(本地和遠程連接同時進行)

5.1 嵌入式模式

在嵌入式模式下,應用程序使用JDBC從同一JVM中打開數據庫。這是最快也是最容易的連接方式。缺點是數據庫可能只在任何時候在一個虛擬機(和類加載器)中打開。與所有模式一樣,支持持久性和內存數據庫。對並發打開數據庫的數量或打開連接的數量沒有限制。

5.2 服務器模式

當使用服務器模式(有時稱為遠程模式或客戶機/服務器模式)時,應用程序使用 JDBC 或 ODBC API 遠程打開數據庫。服務器需要在同一台或另一台虛擬機上啟動,或者在另一台計算機上啟動。許多應用程序可以通過連接到這個服務器同時連接到同一個數據庫。在內部,服務器進程在嵌入式模式下打開數據庫。

服務器模式比嵌入式模式慢,因為所有數據都通過TCP/IP傳輸。與所有模式一樣,支持持久性和內存數據庫。對每個服務器並發打開的數據庫數量或打開連接的數量沒有限制。

5.3 混合模式

混合模式是嵌入式和服務器模式的結合。連接到數據庫的第一個應用程序在嵌入式模式下運行,但也啟動服務器,以便其他應用程序(在不同進程或虛擬機中運行)可以同時訪問相同的數據。本地連接的速度與數據庫在嵌入式模式中的使用速度一樣快,而遠程連接速度稍慢。

服務器可以從應用程序內(使用服務器API)啟動或停止,或自動(自動混合模式)。當使用自動混合模式時,所有想要連接到數據庫的客戶端(無論是本地連接還是遠程連接)都可以使用完全相同的數據庫URL來實現。

以上不同的連接方式對應不同的 JDBC URL,可以參考如下附錄表格中的連接格式。

附錄:H2 數據庫不同模式連接字串

在 H2 的安裝目錄下,如:F:\software\h2\docs\h2.pdf 中,可以查看其幫助文檔。

可參考如下博客文章學習 Java 連接 H2:

Java嵌入式數據庫H2學習總結(一)——H2數據庫入門

Java嵌入式數據庫H2學習總結(二)——在Web應用程序中使用H2數據庫

Java嵌入式數據庫H2學習總結(三)——在Web應用中嵌入H2數據庫

H2數據庫入門Demo詳解

  URL Format and Examples
Embedded (local) connection jdbc:h2:[file:][<path>]<databaseName>
jdbc:h2:~/test
jdbc:h2:file:/data/sample
jdbc:h2:file:C:/data/sample (Windows only)
In-memory (private) jdbc:h2:mem:
In-memory (named) jdbc:h2:mem:<databaseName>
jdbc:h2:mem:test_mem
Server mode (remote connections) using TCP/IP jdbc:h2:tcp://<server>[:<port>]/[<path>]<databaseName>
jdbc:h2:tcp://localhost/~/test
jdbc:h2:tcp://dbserv:8084/~/sample
jdbc:h2:tcp://localhost/mem:test
Server mode (remote connections) using TLS jdbc:h2:ssl://<server>[:<port>]/<databaseName>
jdbc:h2:ssl://localhost:8085/~/sample;
Using encrypted files jdbc:h2:<url>;CIPHER=AES
jdbc:h2:ssl://localhost/~/test;CIPHER=AES
jdbc:h2:file:~/secure;CIPHER=AES
File locking methods jdbc:h2:<url>;FILE_LOCK={FILE|SOCKET|NO}
jdbc:h2:file:~/private;CIPHER=AES;FILE_LOCK=SOCKET
Only open if it already exists jdbc:h2:<url>;IFEXISTS=TRUE
jdbc:h2:file:~/sample;IFEXISTS=TRUE
Don't close the database when the VM exits jdbc:h2:<url>;DB_CLOSE_ON_EXIT=FALSE
Execute SQL on connection jdbc:h2:<url>;INIT=RUNSCRIPT FROM '~/create.sql'
jdbc:h2:file:~/sample;INIT=RUNSCRIPT FROM '~/create.sql'\;RUNSCRIPT FROM '~/populate.sql'
User name and/or password jdbc:h2:<url>[;USER=<username>][;PASSWORD=<value>]
jdbc:h2:file:~/sample;USER=sa;PASSWORD=123
Debug trace settings jdbc:h2:<url>;TRACE_LEVEL_FILE=<level 0..3>
jdbc:h2:file:~/sample;TRACE_LEVEL_FILE=3
Ignore unknown settings jdbc:h2:<url>;IGNORE_UNKNOWN_SETTINGS=TRUE
Custom file access mode jdbc:h2:<url>;ACCESS_MODE_DATA=rws
Database in a zip file jdbc:h2:zip:<zipFileName>!/<databaseName>
jdbc:h2:zip:~/db.zip!/test
Compatibility mode jdbc:h2:<url>;MODE=<databaseType>
jdbc:h2:~/test;MODE=MYSQL
Auto-reconnect jdbc:h2:<url>;AUTO_RECONNECT=TRUE
jdbc:h2:tcp://localhost/~/test;AUTO_RECONNECT=TRUE
Automatic mixed mode jdbc:h2:<url>;AUTO_SERVER=TRUE
jdbc:h2:~/test;AUTO_SERVER=TRUE
Page size jdbc:h2:<url>;PAGE_SIZE=512
Changing other settings jdbc:h2:<url>;<setting>=<value>[;<setting>=<value>...]
jdbc:h2:file:~/sample;TRACE_LEVEL_SYSTEM_OUT=3


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM