<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    捕風(fēng)之巢

    統(tǒng)計(jì)

    留言簿(3)

    java友情鏈接

    閱讀排行榜

    評(píng)論排行榜

    Hsql使用

    前言:該文章只是簡(jiǎn)單介紹一下hsql的入門內(nèi)容,如果想仔細(xì)了解的話,參考官方幫助文檔最為有用。

    一、簡(jiǎn)介:
    hsql 數(shù)據(jù)庫是一款純Java編寫的免費(fèi)數(shù)據(jù)庫,許可是BSD-style的協(xié)議,如果你是使用Java編程的話,不凡考慮一下使用它,相對(duì)其他數(shù)據(jù)庫來說,其體積小,才563kb。僅一個(gè)hsqldb.jar文件就包括了數(shù)據(jù)庫引擎,數(shù)據(jù)庫驅(qū)動(dòng),還有其他用戶界面操作等內(nèi)容。在Java開源世界里,hsql是極為受歡迎的(就Java本身來說),JBoss應(yīng)用程序服務(wù)器默認(rèn)也提供了這個(gè)數(shù)據(jù)庫引擎。由于其體積小的原因,又是純Java設(shè)計(jì),又支持 SQL99,SQL2003大部分的標(biāo)準(zhǔn),所以也是作為商業(yè)應(yīng)用程序展示的一種選擇。請(qǐng)到以下地址下載hsql: http://prdownloads.sourceforge.net/hsqldb/hsqldb_1_7_3_3.zip?download

    二、使用hsql數(shù)據(jù)庫:
    1、hsql數(shù)據(jù)庫引擎有幾種服務(wù)器模式:常用的Server模式、WebServer模式、Servlet模式、Standlone模式、Memory-Only數(shù)據(jù)庫。
    2、最為常用的Server模式:
    1)首先卻換到lib文件夾下,運(yùn)行java -cp hsqldb.jar org.hsqldb.Server -database.0 db/mydb -dbname.0 xdb
    執(zhí)行命令后,將會(huì)在db文件夾下創(chuàng)建一個(gè)數(shù)據(jù)庫mydb,別名(用于訪問數(shù)據(jù)庫)是xdb,如果存在mydb數(shù)據(jù)庫,將會(huì)打開它。
    2)運(yùn)行數(shù)據(jù)庫界面操作工具:java -cp hsqldb.jar org.hsqldb.util.DatabaseManager
    在Type 選項(xiàng)里選上相應(yīng)的服務(wù)器模式,這里選擇HSQL Database Engine Server模式;Driver不用修改;URL修改為jdbc:hsqldb:hsql://localhost/xdb (主要這里xdb就是上面我們?cè)O(shè)置的別名);user里設(shè)置用戶名,第一次登錄時(shí),設(shè)置的是管理員的用戶名,password設(shè)置密碼。然后點(diǎn)擊Ok。
    3)第一次運(yùn)行數(shù)據(jù)庫引擎,創(chuàng)建數(shù)據(jù)庫完畢。好了,你可以打開db文件夾,會(huì)發(fā)現(xiàn)里面多了幾個(gè)文件。
    mydb.properties文件:是關(guān)于數(shù)據(jù)庫的屬性文件。
    mydb.script:hsql主要保存的表(這里按hsql的說法是Memory表,就是最為常用的),里面的格式都是文本格式,可以用文本查看,里面的語句都是sql語句,熟悉sql語句的話,你也可以手動(dòng)修改它。每次運(yùn)行數(shù)據(jù)庫引擎的話都是從這里加載進(jìn)內(nèi)存的。
    mydb.lck表示數(shù)據(jù)庫處于打開狀態(tài)。
    其他的請(qǐng)參看hsqldb包里的手冊(cè)。

    3、WebServer模式和Server運(yùn)行模式基本一樣,只是支持了Http等協(xié)議,主要用于防火墻,默認(rèn)端口是9001。啟動(dòng)Server,java -cp hsqldb.jar org.hsqldb.WebServer ...剩余的和上面的一致。

    4、Servlet模式可以允許你通過Servlet容器來訪問數(shù)據(jù)庫,請(qǐng)查看hsqlServlet.java的源代碼,和WebServer類似。

    5、另一個(gè)值得思考的模式是Standalone模式:不能通過網(wǎng)絡(luò)來訪問數(shù)據(jù)庫,主要是在一個(gè)JVM中使用,那樣的話,訪問的速度會(huì)更加快。雖然文檔里面提到主要是用于開發(fā)時(shí)使用,但是我們可以假設(shè)一下,該方法不需要一個(gè)引擎類的東西,而類似于打開文件的方式,返回一個(gè)Connection對(duì)象:
    Connection c = DriverManager.getConnection("jdbc:hsqldb:file:mydb", "sa", "");
    將會(huì)在當(dāng)前目錄找到mydb數(shù)據(jù)庫相關(guān)文件,打開并返回一個(gè)Connection對(duì)象。該方式有點(diǎn)好處就是可以不使用引擎,在需要的時(shí)候操作數(shù)據(jù)。所以那些對(duì)數(shù)據(jù)庫不是特別有要求的,但又需要一個(gè)操作數(shù)據(jù)庫的方式的話,可以使用這種方法。對(duì)于那些不想額外在數(shù)據(jù)庫引擎花費(fèi)金錢的話,可以使用這種方法。但是不推薦使用該方法。記得Hibernate里SessionFactory可以使用openSession(Connecttion c)來獲得一個(gè)Session對(duì)象的,因此,在測(cè)試或者實(shí)際應(yīng)用的話都可以這樣使用。

    6、Memory-Only 數(shù)據(jù)庫:顧名思義,主要是內(nèi)存中使用,不用于保存數(shù)據(jù)??梢杂糜谠趦?nèi)存中交換數(shù)據(jù)。

    三、具體的鏈接與操作的話,和一般的JDBC操作一樣。而相應(yīng)的Server模式的話,連接地址主要你運(yùn)行數(shù)據(jù)庫界面操作工具時(shí),在URL一欄時(shí)默認(rèn)已經(jīng)設(shè)好了,自己實(shí)習(xí)一下,對(duì)比其中參數(shù)。

    這篇文章介紹大致內(nèi)容很詳細(xì),不過也大都是從Hsql的幫助上翻譯的,我有必要加入點(diǎn)新鮮的血液。
    這篇文章美中不足的是缺少實(shí)戰(zhàn)性,往往初學(xué)者第一步都走不出來,比如我。
    我在實(shí)踐中遇到的問題是打開數(shù)據(jù)庫管理器怎么也連接不上數(shù)據(jù)庫,總是說
    java.sql.sqlException Socket create error
    搞了一個(gè)晚上,到第二天早上清醒一下,想起來這個(gè)數(shù)據(jù)庫應(yīng)該在創(chuàng)建庫之后,保持那個(gè)cmd窗口,在此過程中連接。
    果然好用,也邁出了開拓Hsql的第一步。

    另外不用在互聯(lián)網(wǎng)上搜索別的介紹,Hsql自帶的guide就已經(jīng)很詳細(xì)了。



    Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=472441

    [點(diǎn)擊此處收藏本文]?? whoopee發(fā)表于 2005年09月06日 10:54:00

    相關(guān)文章:

    posted on 2006-10-16 15:10 捕風(fēng) 閱讀(1900) 評(píng)論(0)  編輯  收藏 所屬分類: 數(shù)據(jù)庫技術(shù)

    主站蜘蛛池模板: 亚洲一区二区三区免费| 久久99久久成人免费播放| 九九99热免费最新版| 在线视频免费观看www动漫| 亚洲国产高清视频| 你是我的城池营垒免费看 | 久久久久国产免费| 国产亚洲?V无码?V男人的天堂 | 四虎影视永久在线精品免费| 日韩一区二区a片免费观看| 亚洲国产精品网站久久| 久久中文字幕免费视频| 久久精品国产亚洲av成人| 国产免费一区二区三区免费视频| 国产真人无遮挡作爱免费视频| 国产成人精品亚洲2020| 毛片免费在线播放| 亚洲国产成人精品无码区二本| 成人毛片免费在线观看| 亚洲AV成人无码网天堂| 国产一精品一aⅴ一免费| 香蕉97碰碰视频免费| 区久久AAA片69亚洲| 日韩免费视频一区二区| 亚洲一区免费在线观看| 女人18一级毛片免费观看| 人人狠狠综合久久亚洲| 亚洲国产成人久久笫一页| 成人av片无码免费天天看| 亚洲蜜芽在线精品一区| 日本一道综合久久aⅴ免费| 国产亚洲蜜芽精品久久| 亚洲精品亚洲人成人网| 91麻豆最新在线人成免费观看| 亚洲一卡2卡3卡4卡国产网站| 成人免费午间影院在线观看| 免费精品国产自产拍在线观看 | 亚洲不卡1卡2卡三卡2021麻豆| 国产在线观看www鲁啊鲁免费| 中文毛片无遮挡高清免费| 日韩亚洲产在线观看|