免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開APP
userphoto
未登錄

開通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開通VIP
用XML文件存儲數(shù)據(jù)

1:XML缺少數(shù)據(jù)庫具備的特性:高效的存儲(即使是數(shù)據(jù)庫內(nèi)XML字段還是沒有傳統(tǒng)字段的速度快)、索引和數(shù)據(jù)修改機(jī)制(DB2等數(shù)據(jù)庫產(chǎn)品對XML內(nèi)的元素和屬性可以加索引,內(nèi)建在數(shù)據(jù)庫中的XML字段享受了數(shù)據(jù)庫帶來的一些好處);嚴(yán)格的數(shù)據(jù)安全訪問控制;完整的事務(wù)和數(shù)據(jù)一致性控制;多用戶訪問機(jī)制;觸發(fā)器、完善的并發(fā)控制等因此,用戶量大、數(shù)據(jù)集成度高以及性能要求高的數(shù)據(jù)環(huán)境中還是需要數(shù)據(jù)庫來完成任務(wù),IBM的DB2工程師也在討論時(shí)建議我們統(tǒng)計(jì)類數(shù)據(jù)還是用傳統(tǒng)字段為好。

2:說說 XSL,XSLT文件是用來做XML轉(zhuǎn)換,一般是轉(zhuǎn)換為HTML(XHTML),只是轉(zhuǎn)換的話 XSL 代碼與XML的結(jié)構(gòu)復(fù)雜度有關(guān),與 XML本身有多少數(shù)據(jù)量無關(guān), 為什么會(huì)有幾千萬行的數(shù)據(jù)?你恐怕把 XML 寫成 XSL 了吧,數(shù)據(jù)有幾千萬行才對吧,XSL 不會(huì)很大。

3:真的數(shù)據(jù)源有 幾千萬行的話,是否應(yīng)該存在 XML 文檔中?你可以計(jì)算一下,XML文檔是文本模式存放,一行存放最少算平均20個(gè)字節(jié)有吧(就算10個(gè)漢字),那 1000萬行已經(jīng) 200M 大,不要說 200M,就是20M的文本文件用編輯器打開都會(huì)非常吃力,像死機(jī)一樣,這么大的數(shù)據(jù)量我認(rèn)為不應(yīng)該存在 XML 文件中,應(yīng)存在數(shù)據(jù)庫表中,如果是文件系統(tǒng)應(yīng)該用二進(jìn)制文件存放或根據(jù)用途和管理方案對其分割。XML只適合保存少量數(shù)據(jù),最多不能超過1w

4:數(shù)據(jù)庫中XML數(shù)據(jù)(表轉(zhuǎn)換或通過源生XML字段)讀出通過 XSL 顯示頁面的方式由于沒有了SQL,可以保證頁面代碼與各類數(shù)據(jù)庫產(chǎn)品的無關(guān)性,由于大數(shù)據(jù)量顯示一般都有分頁控制讀取和顯示,性能問題不大。
 
5,現(xiàn)代的數(shù)據(jù)庫大部分都有 XML 字段,可以直接存儲 XML, 不需要經(jīng)過 表 -> XML 的轉(zhuǎn)換,即使沒有 XML 字段,由于XML本身的文本特性,也可以將其作為字符串 或 CLOB 存儲,只有數(shù)據(jù)本身不是XML,而是用二維表格存在數(shù)據(jù)庫中時(shí),才需要 表 -> XML 轉(zhuǎn)換
 
 

把數(shù)據(jù)存儲到 XML 文件

創(chuàng)建并保存 XML 文件

如果數(shù)據(jù)要被傳送到非 Windows 平臺上的應(yīng)用程序,那么把數(shù)據(jù)保存在 XML 文件中是有好處的。請記住,XML 有很強(qiáng)的跨平臺可移植性,并且數(shù)據(jù)無需轉(zhuǎn)換!

首先,我們將學(xué)習(xí)如何創(chuàng)建并保存一個(gè) XML 文件。下面的這個(gè) XML 文件將被命名為 "test.xml",并被保存在服務(wù)器上的 c 目錄中。我們將使用 ASP 和微軟的 XMLDOM 對象來創(chuàng)建并保存這個(gè) XML 文件:

<%Dim xmlDoc, rootEl, child1, child2, p'創(chuàng)建XML文檔Set xmlDoc = Server.CreateObject("Microsoft.XMLDOM")'創(chuàng)建根元素并將之加入文檔Set rootEl = xmlDoc.createElement("root")xmlDoc.appendChild rootEl'創(chuàng)建并加入子元素Set child1 = xmlDoc.createElement("child1")Set child2 = xmlDoc.createElement("child2")rootEl.appendChild child1rootEl.appendChild child2'創(chuàng)建 XML processing instruction'并把它加到根元素之前Set p=xmlDoc.createProcessingInstruction("xml","version='1.0'")xmlDoc.insertBefore p,xmlDoc.childNodes(0)'把文件保存到 C 目錄xmlDoc.Save "c:\test.xml"%>

如果您打開這個(gè)被保存的文件,它會(huì)使這個(gè)樣子 ("test.xml"):

<?xml version="1.0"?><root>  <child1 />  <child2 /></root>

真實(shí)的表單例子

現(xiàn)在,我們看一個(gè)真實(shí)的表單例子。

我們首先看一下這個(gè)被用在例子中的 HTML 表單:下面的HTML表單要求用戶輸入他們的名字、國籍以及電子郵件地址。隨后這些信息會(huì)被寫到一個(gè) XML 文件,以便存儲。

"customers.htm":

<html><body><form action="saveForm.asp" method="post"><h1>請輸入您的聯(lián)系信息:</h1><label>名字: </label><p><input type="text" id="firstName" name="firstName"></p><label>姓氏: </label><p><input type="text" id="lastName" name="lastName"></p><label>國家: </label><p><input type="text" id="country" name="country"></p><label>郵件: </label><p><input type="text" id="email" name="email"></p><p><input type="submit" id="btn_sub" name="btn_sub" value="Submit"><input type="reset" id="btn_res" name="btn_res" value="Reset"></p></form></body></html>

用于以上 HTML 表單的 action 被設(shè)置為 "saveForm.asp"。"saveForm.asp" 文件是一個(gè) ASP 頁面,可循環(huán)遍表單域,并把它們的值存儲在一個(gè) XML 文件中:

<%dim xmlDocdim rootEl,fieldName,fieldValue,attIDdim p,i'如果有錯(cuò)誤發(fā)生,不允許程序終止On Error Resume NextSet xmlDoc = server.CreateObject("Microsoft.XMLDOM")xmlDoc.preserveWhiteSpace=true'創(chuàng)建并向文檔添加根元素Set rootEl = xmlDoc.createElement("customer")xmlDoc.appendChild rootEl'循環(huán)遍歷 Form 集for i = 1 To Request.Form.Count  '除去表單中的 button 元素  if instr(1,Request.Form.Key(i),"btn_")=0 then    '創(chuàng)建 field 和 value 元素,以及 id 屬性    Set fieldName = xmlDoc.createElement("field")    Set fieldValue = xmlDoc.createElement("value")    Set attID = xmlDoc.createAttribute("id")    '把當(dāng)前表單域的名稱設(shè)置為 id 屬性的值    attID.Text = Request.Form.Key(i)    '把 id 屬性添加到 field 元素    fieldName.setAttributeNode attID    '把當(dāng)前表單域的值設(shè)置為 value 元素的值    fieldValue.Text = Request.Form(i)    '將 field 元素作為根元素的子元素進(jìn)行添加    rootEl.appendChild fieldName    '將 value 元素作為 field 元素的子元素進(jìn)行添加    fieldName.appendChild fieldValue  end ifnext'添加 XML processing instruction'并把它加到根元素之前Set p = xmlDoc.createProcessingInstruction("xml","version='1.0'")xmlDoc.insertBefore p,xmlDoc.childNodes(0)'保存 XML 文件xmlDoc.save "c:\Customer.xml"'釋放所有的對象引用set xmlDoc=nothingset rootEl=nothingset fieldName=nothingset fieldValue=nothingset attID=nothingset p=nothing'測試是否有錯(cuò)誤發(fā)生if err.number<>0 then  response.write("Error: No information saved.")else  response.write("Your information has been saved.")end if%>

注釋:如果指定的 XML 文件名已經(jīng)存在,那個(gè)文件會(huì)被覆蓋!

XML 文件會(huì)由上面的代碼生成,大致的樣子是這樣的:("Customer.xml"):

<?xml version="1.0" ?><customer>  <field id="firstName">    <value>David</value>   </field>  <field id="lastName">    <value>Smith</value>   </field>  <field id="country">    <value>China</value>   </field>  <field id="email">    <value>mymail@myaddress.com</value>   </field></customer
 

XML文件XPATH查詢方法

vb中使用DomDocument對象操作xml時(shí),若要使用XPath中的內(nèi)部函數(shù),需要進(jìn)行如下設(shè)置
 
dim dom as DomDocument
dom.setProperty  "SelectionLanguage", "XPath"
 
XML 路徑語言 (XPath) 查詢可以用來利用 DOM 方法 (如 selectNodesselectSingleNode 查詢 XML 文件。預(yù)設(shè)會(huì)使用的查詢是 XSLPattern 回溯相容性。若要用以 XPath 變更 [以 XPath 的 [DOMDocumentSelectionLanguage 內(nèi)部屬性]。XPath 新增很多的功能 ; 比方說它可讓您使用如 字串長度加總 函數(shù)。
下列的程式碼範(fàn)例示範(fàn)如何使用 XPath 與 selectNodes 方法: 
  1. 啟動(dòng) Visual Basic,並建立新的標(biāo)準(zhǔn)執(zhí)行檔。
  2. [] 選取 [專案]、 選取 [參考],然後再新增 [Microsoft XML、 v3.0 的參考]。
  3. 將下列程式碼加入至 Form_Load 事件:
Dim dom As DOMDocument30Dim nodelist As IXMLDOMNodeListDim strPath As String   Set dom = New DOMDocument30dom.async = False   dom.loadXML "<Admin><Area AreaName='a'/></Admin>"   dom.setProperty "SelectionLanguage", "XPath"strPath = "/Admin/Area[string-length(@AreaName) = 1]"Set nodelist = dom.documentElement.selectNodes(strPath)   Debug.Print "Found " & nodelist.length & " Node"

4,執(zhí)行該應(yīng)用程式,並請注意 [即時(shí)運(yùn)算] 視窗會(huì)顯示 找到 1 節(jié)點(diǎn)。

5,若要顯示預(yù)設(shè)的註解出呼叫 setProperty 程式碼行行為。因?yàn)樵賵?zhí)行程式碼會(huì)產(chǎn)生錯(cuò)誤訊息 XSL 模式比對不支援 字串長度 函式。

 
本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊舉報(bào)。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
用dom4j對帶有命名空間的xml文件使用xpath取值
jquery的使用簡化代碼開發(fā)
PHP XML Expat 解析器
Java程序員的10道XML面試題
[精]XPath入門教程
XML DOM介紹
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服