控制臺打印出:1,Hi
server模式
1、直接將jdbc url 改為:jdbc:h2:tcp://localhost/~/test 就行了。因為我們在上面第一步的時候已經在C:\Users\Administrator創建了test數據庫。
你也可以再創建新的數據庫,默認都是保存在C:\Users\Administrator下的。
注意:你必須啟動服務:%H2_HOME%\bin\h2.bat 或者 以服務模式啟動:%H2_HOME%\service\0_run_server_debug.bat ,里面有好幾個腳本把H2部署為服務模式。每次機器啟動后自動啟動H2服務。
2、新建 TestServerH2類 主要代碼
public static void main(String[] a)
throws Exception {
Class.forName("org.h2.Driver");
Connection conn = DriverManager.
getConnection("jdbc:h2:tcp://localhost/~/test", "sa", "");
// add application code here
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM TEST ");
while(rs.next()) {
System.out.println(rs.getInt("ID")+","+rs.getString("NAME"));
}
conn.close();
}
運行的結果和上面一樣。
內存模式(數據只保存在內存中)
1、新建 TestMemH2類 主要代碼
public static void main(String[] a)
throws Exception {
Class.forName("org.h2.Driver");
Connection conn = DriverManager.
getConnection("jdbc:h2:tcp://localhost/mem:test2", "sa", "");
// add application code here
Statement stmt = conn.createStatement();
stmt.executeUpdate("CREATE TABLE TEST_MEM(ID INT PRIMARY KEY,NAME VARCHAR(255));");
stmt.executeUpdate("INSERT INTO TEST_MEM VALUES(1, 'Hello_Mem');");
ResultSet rs = stmt.executeQuery("SELECT * FROM TEST_MEM");
while(rs.next()) {
System.out.println(rs.getInt("ID")+","+rs.getString("NAME"));
}
conn.close();
}
控制臺打印出:1,Hello_Mem
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
集群 / 高可用性
數據庫支持簡單的集群/高可用性機制。架構是:兩個數據庫服務運行在兩臺不同的計算機上,兩臺計算機有同樣數據庫的副本,如果兩個服務器都處于運行狀態,每個數據庫操作都被在兩臺計算機上執行,如果一臺服務器宕機(斷電、硬件故障、網絡故障等),另外一臺計算機仍能提供服務,從這一刻開始,數據庫操作僅在一臺服務器上執行,直到另外一臺服務器恢復運行。
集群僅能用于服務器模式(內嵌模式并不支持集群)。可以在數據庫運行狀態下恢復集群,但是要求在第二個數據庫恢復期間沒有應用在改變第一個數據庫的數據,因此恢復集群是一個手工的過程。
初始化集群,使用下面的步驟:
· 創建數據庫
· 使用CreateCluster工具創建一個數據庫福分到另外的地方,并且初始化集群,這樣就得到了同樣數據的兩個數據庫
· 啟動兩個數據庫服務(每個數據庫的副本)
· 現在可以通過應用客戶端連接到數據庫
使用創建集群工具
要了解集群如何工作,請嘗試下面的例子,在這個例子里,兩個數據庫駐留在同一臺計算機上,但通常,兩個數據庫在不同的計算機上。
· 創建兩個目錄:server1,server2。每個目錄將模擬一臺計算機
· 在第一個目錄啟動TCP服務,你可以運行下面的命令:
· java org.h2.tools.Server
· -tcp-tcpPort 9101
· -baseDirserver1
· 在第二個目錄啟動TCP服務,模擬第二個服務器(冗余運行),你能使用下面的命令:
· java org.h2.tools.Server
· -tcp-tcpPort 9102
· -baseDirserver2
· 使用 CreateCluster 工具初始化集群,如果數據庫不存在,將創建一個新的空數據庫,運行下面命令行:
· java org.h2.tools.CreateCluster
· -urlSourcejdbc:h2:tcp://localhost:9101/~/test
· -urlTargetjdbc:h2:tcp://localhost:9102/~/test
· -user sa
· -serverList localhost:9101,localhost:9102
· 應用或者是H2控制臺可以通過下面的JDBC的URL連接數據庫:jdbc:h2:tcp://localhost:9101,localhost:9102/~/test
· 如果你停止一個服務(通過殺進程),你注意到另一個機器繼續工作,數據庫仍能提供訪問。
· 恢復集群,你需要先刪掉宕機的數據庫,然后重啟宕機的數據庫的服務,再重新運行CreateCluster集群工具。
檢測運行狀態下的集群
查找哪些節點當前正在運行,通過執行下面的SQL語句:
SELECT VALUE FROM INFORMATION_SCHEMA.SETTINGS WHERENAME='CLUSTER'
結果返回為 '' (兩個單引號),說明集群模式被屏蔽,否則,集群服務器列表將被單引號包括著返回,如'server1:9191,server2:9191'。
2、上面的 URL 改為 jdbc:h2:~/mem:test 也是可以的。如果是localhost必須啟動服務。
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
數據庫連接 URL說明
數據庫支持多種連接模式和連接設置,不同的連接模式和連接設置是通過不同的URL來區分的,URL中的設置是不區分大小寫。
Topic |
URL Format and Examples |
嵌入式(本地)連接 |
jdbc:h2:[file:][ |
內存數據庫(私有) |
jdbc:h2:mem: |
內存數據庫(被命名) |
jdbc:h2:mem: |
使用TCP/IP的服務器模式(遠程連接) |
jdbc:h2:tcp:// |
使用SSL/TLS的服務器模式(遠程連接) |
jdbc:h2:ssl:// |
使用加密文件 |
jdbc:h2:;CIPHER=[AES|XTEA] |
文件鎖 |
jdbc:h2:;FILE_LOCK={NO|FILE|SOCKET} |
僅打開存在的數據庫 |
jdbc:h2:;IFEXISTS=TRUE |
當虛擬機退出時并不關閉數據庫 |
jdbc:h2:;DB_CLOSE_ON_EXIT=FALSE |
用戶名和密碼 |
jdbc:h2:[;USER=][;PASSWORD= |
更新記入索引 |
jdbc:h2:;LOG=2 |
調試跟蹤項設置 |
jdbc:h2:;TRACE_LEVEL_FILE= |
忽略位置參數設置 |
jdbc:h2:;IGNORE_UNKNOWN_SETTINGS=TRUE |
指定文件讀寫模式 |
jdbc:h2:;ACCESS_MODE_LOG=rws;ACCESS_MODE_DATA=rws |
在Zip文件中的數據庫 |
jdbc:h2:zip: |
兼容模式 |
jdbc:h2:;MODE= |
自動重連接 |
jdbc:h2:;AUTO_RECONNECT=TRUE |
自動混合模式 |
jdbc:h2:;AUTO_SERVER=TRUE |
更改其他設置 |
jdbc:h2:; |
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com