xml數(shù)據(jù)庫越來越吃香啦。
今天我們來研究asp操作xml數(shù)據(jù)庫的常用經(jīng)典代碼備忘
no.1--建立一個(gè)xml數(shù)據(jù)庫data.xml
程序代碼
caca
154222225
root@3ney.com
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("
nodename:"&node.nodename&"
nodetypestring:"&node.nodetypestring&"
nodevalue:"&node.nodevalue&"
text:"&node.text&"
node.childnodes.length:"&node.childnodes.length&"")
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è)方法,比如定位
xmldoc.selectsinglenode("http://name")
no.4--給節(jié)點(diǎn)賦值(修改節(jié)點(diǎn)的值)
學(xué)會(huì)了定位節(jié)點(diǎn),利用其屬性,就可以修改或者賦值了
例如,把的值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è),只需要一句就搞定:
xmldoc.selectsinglenode("http://record").appendchild(xmldoc.createelement(""))
給賦值
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)的特征
例如:刪除節(jié)點(diǎn)
xmldoc.selectsinglenode("http://record").removechild(xmldoc.selectsinglenode("http://qq"))
例如:刪除那個(gè)=caca的
xmldoc.selectsinglenode("http://records").removechild(xmldoc.selectsinglenode("http://record[name='caca']))
xmldoc.save(server.mappath("data.xml"))
只有能熟練這6條code,用asp控制xml數(shù)據(jù)庫,也就差不多了...
該文章在 2010/7/22 21:48:45 編輯過