asp控制xml數據庫的6條實用代碼_ASP教程
推薦:ASP操作XML文件的主要方法和實現ASP通過XMLDom在服務器端操作XML文件的主要方法和實現 對于小數據量,xml文件在檢索更新上于ACCESS有很多優勢。 我曾經測試過不用數據庫,把網站的會員信息,商品數據信息,交易信息,網站定制信息全部存放在三個xml文件中,運行結果十分正常,感覺上比數據
很多朋友會偶爾遇到需要asp控制xml數據庫,現在整理一下asp控制xml數據庫的相關代碼。
共六條,代碼如下:
asp控制xml數據庫代碼1--建立一個XML數據庫data.xm
<?xml version="1.0"?>
<records>
<record>
<name>caca</name>
<qq>154222225</qq>
<email>root@3ney.com</email>
</record>
<records>
asp控制xml數據庫代碼2--建立對象CreateObject
建立data.xml的對象先
set xmldoc=server.createobjcet("microsoft.xmldom")
xmldoc.load(server.mappath("data.xml")
asp控制xml數據庫代碼3--選定節點SelectNode
你想操作哪個Node,必須定位到這個節點是不是,先看看這個data.xml有幾個Node??
用一個遞歸函數搞定:
getnodes(xmldoc)
sub getnodes(node)
dim i
response.write("<br><b>NodeName:</b>"&node.nodename&"<br><b>NodeTypeString:</b>"&node.nodetypestring&"<br><b>NodeValue:</b>"&node.nodevalue&"<br><b>Text:</b>"&node.text&"<br><b>node.childnodes.length:</b>"&node.childnodes.length&"<p>") Webjx.Com
if node.childnodes.length<>0 then
for i=0 to node.childnodes.length-1
getnodes(node.childnodes(i))
next
end if
end sub
用這個函數后,可以看到這個data.xml有10個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
是不是定位很簡單呀,還有個方法,比如定位<name>
xmldoc.selectsinglenode("//name")
asp控制xml數據庫代碼4--給節點賦值(修改節點的值)
學會了定位節點,利用其屬性,就可以修改或者賦值了
例如,把<name>的值caca改為wawa
xmldoc.selectsinglenode("//name").text="wawa" Webjx.Com
xmldoc.save(server.mappath("data.xml"))
搞定!
NO.5--創建新的節點CreatenewNode
用createelement或者createnode("","","")
例如:在record下新建個<age>,只需要一句就搞定:
xmldoc.selectsinglenode("//record").appendchild(xmldoc.createelement("<age>"))
給<age>賦值
xmldoc.selectsinglenode("//age").text="20"
xmldoc.save(server.mappath("data.xml"))
搞定!
asp控制xml數據庫代碼6--刪除一個節點DeleteNode
你必須明確你想刪除的這個節點的父節點,以及這個節點的特征
例如:刪除<qq>節點
xmldoc.selectsinglenode("//record").removechild(xmldoc.selectsinglenode("//qq"))
例如:刪除那個<name>=caca的<record>
xmldoc.selectsinglenode("//records").removechild(xmldoc.selectsinglenode("//record[name='caca']))
xmldoc.save(server.mappath("data.xml")) Webjx.Com
搞定!
掌握了這6條asp控制xml數據庫的代碼,用asp控制xml數據庫,就會簡單很多.
分享:ASP對XML文檔中文本的增加、刪除、修改、查看% '---------------------------------------------------------------- '程序簡介: 完成asp語言對XML文檔中指定節點文本的增加、刪除、修改、查看 '入口參數: 無 '出口參數: 無 '------------------------------------------------ '函數名字:ConnectXml()
- 相關鏈接:
- 教程說明:
ASP教程-asp控制xml數據庫的6條實用代碼。