999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

一種基于關系的X ML原型系統的設計與實現

2014-07-11 02:38:44
科技視界 2014年8期
關鍵詞:結構

燕 衛

(廈門海洋職業技術學院,福建 廈門361012)

隨著XML的廣泛應用,XML正在成為數量龐大的數據源,如何利用RDBMS強大數據管理功能管理XML數據已成為一個研究熱點,由于XML數據與關系數據庫的數據模型不同,實現XML數據與數據庫數據的相互轉換顯得尤為重要。

1 數據轉換的設計方案

將XML文檔映射為關系模式進行存儲,有兩大類映射方法:模型映射和結構映射。對于模型映射,利用xml文檔中的數據模型的結構顯性或隱性地映射成其他數據模型的結構,要實現數據庫和xml文檔間的數據轉換的關鍵是在數據庫模式和schemas和DTD之間建立映射關系,用具體的模型來實現數據間的映射。

1.1 邊模型映射方法

一個XML文檔是一個樹狀結構,能夠用一個有序有向邊標記圖來表示,按深度有限的原則從樹葉往樹根搜索,每碰到一個內部節點則創建對應的抽象數據類型,直到根節點的直接子節點,創建基于次根節點所對應的抽象數據類型對象,該對象就是根節點對應的對象,最后將XML文檔中各元素的屬性值填入對象中的相應域。

有了XML圖之后,用來存儲邊信息的邊表有三種設計方案:Edge、Binary、Universal三種邊表設計方案和兩種值表設計方案,一共有六種存儲模式。通過對結構關系數據庫大小,執行不同類型XML查詢的執行時間,從關系數據重構XML文檔的時間等三個性能參數進行量化分析,結論是:Binary邊表帶內聯值表的存儲模式能獲得最好的綜合性能。

1.2 數據模型

一個XML文檔可以被建模為一個樹,因此,一個XML文檔的集合可以被建模為一個森林。一個根結點的樹指向一個XML文檔,一個根結點是非文檔結點的樹指向一個XML文檔片段。因此一個XML查詢即可以在一個XML文檔樹或文檔森林上進行,也可以在一個XML文檔片段或森林片段上進行。

如何從一個DTD生成一個關系型結構?對于每種包含元素或者混合內容的元素類型,新建一個表和一個主鍵字段,對于每個包含混合內容的元素類型,創建一個單獨的表格,其中存放未析數據,通過父元素主鍵鏈接到父表格,對每個有元素或者混合內容的子元素,通過父元素主鍵將父元素表格和子元素表格相連接。

如何從一個關系型的結構生成一個DTD?對于每個表新建一個元素,對于表格中的每個字段,新建一個屬性或者是只包含未析數據的子元素;對于每個表格字段中提供主鍵的主鍵/外鍵的關系都新建一個子元素。

1.3 擴展先序列表

為了有效地實現對文檔樹中任意兩個結點對之間的祖先/后裔關系,利用擴展先序列表寫出它的先序遍歷序列,然后根據圖中各個節點左右孩子的狀況進行加以遍歷。基于節點的索引本質上即是將XML數據分解為數據單元的記錄集合,同時在記錄中保存該單元在XML數據中的位置信息。通過編碼技術索引每一個節點,節點之間的結構關系通過編碼可以在常數時間內確定它可以很好地支持正則路徑表達式。

2 XML文檔到關系數據庫的映射方案

2.1 XML文檔到關系數據庫映射

XML文檔到數據庫的映射往往忽略XML文檔的物理結構(例如實體、引用文本部分及編碼信息)及某些邏輯結構(如處理指令、注釋以及子元素和模型組在元素聲明中出現的順序)。因為數據庫和應用程序只關心XML文件中的數據,因此在映射算法中先不考慮這些物理結構和邏輯結構的映射。

2.2 文檔轉換到關系數據庫的算法描述

根據上述映射規則,可以將元素之間的樹型關系存入RDBMS。不過,首先需要對XML文檔進行解析以獲得DOM樹,并且要給DOM樹中的每個元素節點分別綁定唯一的ID(這在遍歷DOM樹時實現)。事先建一張元素關系表,表的字段分別代表當前元素節點的ID、當前元素節點的父節點ID、當前元素節點的名稱。然后根據上述算法對XML文檔進行解析。

2.3 關系數據庫中的數據恢復成XML形式的算法描述

根據上述的存儲策略,可以從關系數據庫中將數據恢復成XML形式:根據元素關系表來建立XML文檔中元素的嵌套關系,并分別查詢元素內容表和屬性值表來將各元素的內容和各元素的屬性及值插入元素節點。

3 原型系統的設計與實現

這個原型系統實現了兩種方法的存儲,一種是以塊結構存儲,第二種以模型為基礎的映射存儲,通過原型的實現讓我們可以更加清楚直觀的理解XML存儲到關系數據庫的概念。

整個原型系統的工作流程是將讀入的XML文件經過解析遍歷,并在遍歷的同時進行判斷結點類型,插入相應的關系數據庫表中。

3.1 功能模塊

(1)classRdb主要用于創建數據庫的連接。

(2)classtest主要用于實現解析文檔并映射到關系數據庫的工作,這是對于上述算法的具體實現,主要實現函數有test(),stepThrough(Node start),complex(Node node)。

(3)classblobstore主要用于以塊結構存儲XML文檔。

3.2 界面模塊

(1)classAppFrame中調用了javax.swing.filechooser.*;這個包并重載了它,使它實現了對于文件過濾的功能。

(2)classsccuce用來判斷文件存儲成功與否,使用了彈出框的形式。

(3)classErrorDialog可以用來顯示程序運行過程中的一些異常,如文件已經存在關系數據庫中的重復存儲的異常。

猜你喜歡
結構
DNA結構的發現
《形而上學》△卷的結構和位置
哲學評論(2021年2期)2021-08-22 01:53:34
論結構
中華詩詞(2019年7期)2019-11-25 01:43:04
新型平衡塊結構的應用
模具制造(2019年3期)2019-06-06 02:10:54
循環結構謹防“死循環”
論《日出》的結構
縱向結構
縱向結構
我國社會結構的重建
人間(2015年21期)2015-03-11 15:23:21
創新治理結構促進中小企業持續成長
現代企業(2015年9期)2015-02-28 18:56:50
主站蜘蛛池模板: 国内黄色精品| 国产麻豆精品久久一二三| 亚洲无码免费黄色网址| 国产精品xxx| 特级aaaaaaaaa毛片免费视频| 欧美h在线观看| 国产精品综合久久久| 国产福利免费视频| 中日韩一区二区三区中文免费视频| 制服丝袜一区二区三区在线| 婷婷六月综合网| 91丝袜美腿高跟国产极品老师| 91小视频在线| 亚洲国产欧美中日韩成人综合视频| 亚洲人免费视频| 在线播放精品一区二区啪视频| 美女黄网十八禁免费看| 亚洲视频四区| 免费一级毛片在线观看| 在线色综合| 亚洲国产一区在线观看| 97se亚洲综合不卡| 四虎国产在线观看| 亚洲天堂精品在线| 亚洲精品视频网| 99精品这里只有精品高清视频| 97se综合| 亚洲视频三级| 国产在线观看第二页| 成年看免费观看视频拍拍| 免费A级毛片无码免费视频| 天天激情综合| 国产精品任我爽爆在线播放6080| 国产在线自在拍91精品黑人| 久久综合干| 精品夜恋影院亚洲欧洲| 91精品伊人久久大香线蕉| 亚洲无码高清免费视频亚洲| 动漫精品中文字幕无码| 国产精品蜜臀| 国产91成人| 19国产精品麻豆免费观看| 成人免费网站久久久| 欧美人与动牲交a欧美精品| 久久国产精品夜色| 欧美国产三级| 免费毛片a| 久久a毛片| 自拍偷拍欧美| 这里只有精品在线播放| 九九九久久国产精品| 亚洲国产中文精品va在线播放 | 香蕉在线视频网站| 国产成在线观看免费视频| 国产麻豆精品手机在线观看| 国产成人福利在线视老湿机| 精品国产91爱| 视频一本大道香蕉久在线播放| 55夜色66夜色国产精品视频| 国产亚洲美日韩AV中文字幕无码成人 | 色AV色 综合网站| 国产精品亚洲天堂| 成人亚洲天堂| 2020最新国产精品视频| 香蕉蕉亚亚洲aav综合| 精品少妇人妻无码久久| 亚洲视频无码| 97亚洲色综久久精品| 亚洲妓女综合网995久久| JIZZ亚洲国产| 超碰免费91| 日韩免费毛片视频| 欧美 国产 人人视频| 91麻豆精品国产高清在线| a色毛片免费视频| 四虎永久免费网站| 亚洲第七页| 久久毛片免费基地| 色综合日本| 亚洲福利片无码最新在线播放| 粗大猛烈进出高潮视频无码| 国产成人精品一区二区秒拍1o|