asp控制xml數(shù)據(jù)庫的經(jīng)典代碼
NO.1--建立一個(gè)XML數(shù)據(jù)庫data.xml
<?xml version="1.0"?> <records> <record> <name>caca</name> <qq>154222225</qq> <email>root@3ney.com</email> </record> <records>
NO.2--建立對象CreateObject
建立data.xml的對象先
set xmldoc=server.createobjcet("microsoft.xmldom") xmldoc.load(server.mappath("data.xml")
NO.3--選定節(jié)點(diǎn)SelectNode
你想操作哪個(gè)Node,必須定位到這個(gè)節(jié)點(diǎn)是不是,先看看這個(gè)data.xml有幾個(gè)Node??
用一個(gè)遞歸函數(shù)搞定:
getnodes(xmldoc) sub getnodes(node) dim i response.write(" <b>NodeName:</b>"&node.nodename&" <b>NodeTypeString:</b>"&node.nodetypestring&" <b>NodeValue:</b>"&node.nodevalue&" <b>Text:</b>"&node.text&" <b>node.childnodes.length:</b>"&node.childnodes.length&"<p>") if node.childnodes.length<>0 then for i=0 to node.childnodes.length-1 getnodes(node.childnodes(i)) next end if end sub
用這個(gè)函數(shù)后,可以看到這個(gè)data.xml有10個(gè)Node
這些Node可以很簡單的定位:
xmldoc.childnodes(0) xmldoc.childnodes(1) xmldoc.childnodes(1).childnodes(0) xmldoc.childnodes(1).childnodes(0).childnodes(0) xmldoc.childnodes(1).childnodes(0).childnodes(0).text xmldoc.childnodes(1).childnodes(0).childnodes(1) xmldoc.childnodes(1).childnodes(0).childnodes(1).text xmldoc.childnodes(1).childnodes(0).childnodes(2) xmldoc.childnodes(1).childnodes(0).childnodes(2).text
是不是定位很簡單呀,還有個(gè)方法,比如定位<name>
xmldoc.selectsinglenode("http://name")
NO.4--給節(jié)點(diǎn)賦值(修改節(jié)點(diǎn)的值)
學(xué)會了定位節(jié)點(diǎn),利用其屬性,就可以修改或者賦值了
例如,把<name>的值caca改為wawa
xmldoc.selectsinglenode("http://name").text="wawa" xmldoc.save(server.mappath("data.xml"))
NO.5--創(chuàng)建新的節(jié)點(diǎn)CreatenewNode
用createelement或者createnode("","","")
例如:在record下新建個(gè)<age>,只需要一句就搞定:
xmldoc.selectsinglenode("http://record").appendchild(xmldoc.createelement("<age>"))
給<age>賦值
xmldoc.selectsinglenode("http://age").text="20" xmldoc.save(server.mappath("data.xml"))
NO.6--刪除一個(gè)節(jié)點(diǎn)DeleteNode
你必須明確你想刪除的這個(gè)節(jié)點(diǎn)的父節(jié)點(diǎn),以及這個(gè)節(jié)點(diǎn)的特征
例如:刪除<qq>節(jié)點(diǎn)
xmldoc.selectsinglenode("http://record").removechild(xmldoc.selectsinglenode("http://qq"))
例如:刪除那個(gè)<name>=caca的<record>
xmldoc.selectsinglenode("http://records").removechild(xmldoc.selectsinglenode("http://record[name='caca'])) xmldoc.save(server.mappath("data.xml"))
以上六段經(jīng)典代碼相信一定會對大家利用asp控制xml數(shù)據(jù)庫有所幫助。
相關(guān)文章
ASP通過ODBC連接SQL Server 2008數(shù)據(jù)庫的方法
這篇文章主要介紹了ASP通過ODBC連接SQL Server 2008數(shù)據(jù)庫的方法,需要的朋友可以參考下2015-08-08asp中將字符串轉(zhuǎn)數(shù)字的函數(shù)小結(jié)
這篇文章主要介紹了asp中將字符串轉(zhuǎn)數(shù)字的函數(shù)小結(jié),需要的朋友可以參考下2020-09-09ASP的URLDecode函數(shù)URLEncode解碼函數(shù)
我們知道,ASP的Server對象有個(gè)URLEncode方法可以對地址進(jìn)行編碼,但卻沒有相應(yīng)的解碼函數(shù),下邊的這個(gè)函數(shù)可以實(shí)現(xiàn)對URLEncode的解碼。2010-12-12asp Response.flush 實(shí)時(shí)顯示進(jìn)度
如果你知道Response.Flush和Response.Clear,那你就可以不用這樣的等待了。每生成一個(gè)Html頁面,就用Response.write立即返回一條信息,提示該條數(shù)據(jù)庫記錄已經(jīng)生成Html。2008-08-08asp中判斷服務(wù)器是否安裝了某種組件的函數(shù)
檢查是否存在系統(tǒng)組件或組件是否安裝成功,方便繼續(xù)的操作。給用戶更好的信息指示。2010-12-12