參與人員:
發(fā)布記錄:
版本 |
日期 |
作者 |
說(shuō)明 |
1.0 |
2005-10-25 |
柯自聰 |
創(chuàng)建,第一版 |
|
|
|
|
鏈接:
OpenDoc版權(quán)說(shuō)明:
本文檔版權(quán)歸原作者所有。
在免費(fèi)、且無(wú)任何附加條件的前提下,可在網(wǎng)絡(luò)媒體中自由傳播。
如需部分或者全文引用,請(qǐng)事先征求作者意見(jiàn)。
如果本文對(duì)您有些許幫助,表達(dá)謝意的最好方式,是將您發(fā)現(xiàn)的問(wèn)題和文檔改進(jìn)意見(jiàn)及時(shí)反饋給作者。當(dāng)然,倘若有時(shí)間和能力,能為技術(shù)群體無(wú)償貢獻(xiàn)自己的所學(xué)為最好的回饋。
Liferay Portal 系列文章—Portal數(shù)據(jù)持久.......................................................................... 1
一、HSQL數(shù)據(jù)庫(kù)....................................................................................................... 3
1.1 HSQL簡(jiǎn)介.................................................................................................... 3
1.2 HSQL的特性................................................................................................ 4
1.3 使用HSQL的軟件......................................................................................... 5
1.4 學(xué)些HSQL的資源......................................................................................... 5
二、定制Portal數(shù)據(jù)源(針對(duì)Ent版本)................................................................ 5
Liferay Portal支持個(gè)性化桌面定制,用戶可以隨時(shí)定制和修改自己的桌面,添加、刪除和修改桌面上的Portlet。這些定制信息都隨時(shí)被持久化到數(shù)據(jù)庫(kù)中。如果留心一下,可以在{PORTAL_HOME}\conf\Catalina\localhost\ liferay.xml 找到Liferay Portal使用的連接池。

在{PORTAL_HOME} \common\lib\ext 目錄下,能夠找到一個(gè)hsql.jar,這個(gè)就是數(shù)據(jù)庫(kù)引擎包。
默認(rèn)的,Liferay Portal集成HSQL數(shù)據(jù)庫(kù)作為持久化數(shù)據(jù)庫(kù),所有的定制信息都能夠隨時(shí)添加到HSQL數(shù)據(jù)庫(kù)中,以相應(yīng)用戶的定制。用戶可以根據(jù)需要修改連接池配置,選擇自己方便合適的數(shù)據(jù)庫(kù)。
HSQL是一個(gè)完全用Java編寫的輕量級(jí)數(shù)據(jù)庫(kù)。在本文寫作的時(shí)候,HSQL 1.8.0已經(jīng)正式發(fā)布。相比1.7.2版本,一年多的研發(fā)投入,使得HSQL的引擎更強(qiáng)大,SQL性能更好,支持最多8GB的數(shù)據(jù)量。
HSQL數(shù)據(jù)庫(kù)是一個(gè)完全使用Java編寫得領(lǐng)先的關(guān)系數(shù)據(jù)庫(kù)引擎。它集成了JDBC驅(qū)動(dòng),支持ANSI-92-SQL以及SQL99和2003,提供了一個(gè)精練的(小于100K的Applet形式)、快速的數(shù)據(jù)庫(kù)引擎,支持內(nèi)存和磁盤表結(jié)構(gòu),支持集成和服務(wù)器模式。另外的,它包含了小型的web 服務(wù)器,基于內(nèi)存的查詢和管理工具(作為Applet運(yùn)行),以及一系列的范例。
現(xiàn)在,HSQL已經(jīng)被很多開源項(xiàng)目和商業(yè)產(chǎn)品用作數(shù)據(jù)庫(kù)和持久化引擎。它的精練、能夠完全在內(nèi)存中運(yùn)行的能力、彈性和速度為大家所稱道。
- 100% Java 編寫
- 完全的關(guān)系數(shù)據(jù)庫(kù),支持Java對(duì)象
- 支持JDK1.1.x、1.2.x、1.3.x、1.4.x以及更高版本
- 快速啟動(dòng),支持select、insert、delete、update操作
- 支持標(biāo)準(zhǔn)SQL語(yǔ)法
- 支持內(nèi)連接和外連接,交叉查詢
- 支持分級(jí)查詢,包括IN、EXISTS、ANY、ALL等關(guān)聯(lián)查詢
- 支持視圖、臨時(shí)表和序列
- 支持單列或者多列的主鍵,唯一和確認(rèn)約束
- 支持單列或者多列的索引
- 支持ORDER BY,GROUP BY ,HAVING語(yǔ)法
- 支持COUNT、SUM、MIN、MAX、AVG和其他統(tǒng)計(jì)功能(表達(dá)式或者函數(shù))
- 完全支持諸如CASE…WHEN…ELSE…NULL…IF等的SQL表達(dá)式
- 支持SQL標(biāo)準(zhǔn)的自動(dòng)增長(zhǎng)列和序列
- 支持COMMIT、ROLLBACK和SAVEPOINT事務(wù)
- 支持刪除、更新、清空和默認(rèn)操作的數(shù)據(jù)一致性(外鍵)
- 每個(gè)庫(kù)擁有多個(gè)schemata
- Java保存過(guò)程和函數(shù)
- 觸發(fā)器
- 支持密碼、GRANT和REVOKE的用戶權(quán)限和角色,確保數(shù)據(jù)庫(kù)安全
- 擴(kuò)展ALTER TABLE命令,允許更改列類型
- 內(nèi)存表,以便快速操作
- 磁盤表,以便支持大量數(shù)據(jù)
- 擴(kuò)展的諸如CSV文件的文本表
- 內(nèi)存(比如Applet)、集成(比如加入Java應(yīng)用)和C/S操作模式
- 三種客戶端連接模式:HSQL、HTTP、HSQL-BER,可以采用SSL協(xié)議作為HTTP web服務(wù)器運(yùn)行。
- 可以在Applet、只讀media、集成jar、webstart和集成應(yīng)用中使用
- 每個(gè)虛擬機(jī)多個(gè)實(shí)例
- 磁盤表可以達(dá)到8GB,文本表可以達(dá)到2GB
- 每個(gè)字符和二進(jìn)制數(shù)據(jù)的長(zhǎng)度取決于內(nèi)存
- 完全支持PreparedStatement對(duì)象以加速查詢過(guò)程
- 支持95%以上的JDBC接口,包括批量抓取和可回滾的ResuletSet
- 支持所有JDBC數(shù)據(jù)類型,包括Object、Boolean、Blob、Clob
- 完全支持DatabaseMetaData和ResultSetMetaData
- 帶或者不帶數(shù)據(jù)的SQL腳本垃圾收集
- 強(qiáng)大的基于Java命令和GUI數(shù)據(jù)庫(kù)管理工具
1.3 使用HSQL的軟件
開源軟件:
Open Office 2.0
JBoss
JFox
Jonas
Hibernate
ObJectRelationalBridge – OJB
Mr. Persister ORM
CJDBC
商業(yè)軟件:
Mathematica
Jira
TrackStudio
1.4 學(xué)些HSQL的資源
官方網(wǎng)站:http://www.hsqldb.org/
Sourceforge的官方頁(yè)面:http://sourceforge.net/projects/hsqldb
下載地址:http://sourceforge.net/project/showfiles.php?group_id=23316
一個(gè)簡(jiǎn)單的操作例子:http://blog.csdn.net/whoopee/archive/2005/09/06/472441.aspx
Liferay Portal Ent沒(méi)有特別依賴于某種數(shù)據(jù)庫(kù)。為實(shí)現(xiàn)這個(gè)目標(biāo),所有的業(yè)務(wù)邏輯都被集中在中間層,而且跟數(shù)據(jù)庫(kù)低耦合。這意味著Portal不依賴于特定數(shù)據(jù)庫(kù)的存儲(chǔ)過(guò)程或者生成關(guān)鍵字。
假設(shè)已經(jīng)將Portal Ent版本的源碼下載到{PORTAL_SRC_HOME}目錄廈,要運(yùn)行創(chuàng)建庫(kù)和插入數(shù)據(jù)的腳本,命令行下轉(zhuǎn)到{PORTAL_SRC_HOME}\portal-ejb 目錄,運(yùn)行Ant命令:ant build-db。這個(gè)命令會(huì)為DB2、Firebird、Hypersonic、Interbase、JdataStore、MySQL、Oracle、PostgreSQL和SQL Server運(yùn)行腳本。
所運(yùn)行的SQL腳本在{PORTAL_SRC_HOME}\sql\portal目錄下,命名為portal-db2.sql、portal-firebird.sql、portal-hypersonic.sql、portal-interbase.sql、portal-jdatastore.sql、portal-mysql.sql、portal-oracle.sql、portal-postgrresql.sql和portal-sql-server.sql。可以從這里下載包含上述sql文件的zip壓縮包。
http://prdownloads.sourceforge.net/lportal/liferay-portal-ent-3.6.0-sql.zip
庫(kù)表創(chuàng)建完成之后,就可以修改{PORTAL_HOME}\conf\Catalina\localhost\ liferay.xml,把連接池改為相應(yīng)的數(shù)據(jù)庫(kù)。具體的例子可以參照documenttation。
http://localhost/web/guest/documentation/development/databases
posted on 2005-10-25 16:33
eamoi 閱讀(8000)
評(píng)論(5) 編輯 收藏 所屬分類:
Java