麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > XML > 正文

用XML和SQL 2000來管理存儲過程調用

2024-09-05 20:53:27
字體:
來源:轉載
供稿:網友

創建多個帶有不同參數的存儲過程(stored procedure)來完成同一個任務總是一個很大的負擔。利用XML字符串向你的存儲過程發送參數就能夠簡化這個任務;這也讓COM組件的設計更簡單。 

實現這個目的的方法是將你的參數作為一個XML字符串來傳遞,并剖析XML來取回你所需要的數據,然后繼續實現你所需要集成的功能。你不僅可以通過XML來獲取一些參數,你還可以對XML所創建的DOM文檔運行查詢,以此來封裝多個存儲過程。我會提供一些例子,告訴你如果實現這個目的,并簡要地描述每個例子。

在本例里,為了更新一個Customer表格里的姓名字段,我會傳遞幾個參數。為了獲得customerid(身份列)和新的姓名字段,XML會被剖析。我傳遞給過程的XML字串就像下面的這樣:

<root><Customer><customerid>3</customerid><name>Acme
 Inc.</name></Customer></root>

要被創建的存儲字段就像下面的這樣:


CREATE PROCEDURE update_Customer (@xmldatavarchar(8000)) AS
DECLARE @customeridint
DECLARE @customernamevarchar(50)
DECLARE @xmldata_idint

EXEC sp_xml_preparedocument @xmldata_id OUTPUT, @xmldata, ''

SELECT @customerid = customerid, @customername = [name] FROM
 OPENXML(@xmldata_id, '//Customer', 2) WITH (customeridint, [name]
 varchar(50))

EXEC sp_xml_removedocument @xmldata_id

UPDATE Customer SET Customer.[name] = ISNULL(@customername, Customer.[name])
WHERE Customer.tblID = @customerid

 

這個過程首先就聲明我們將要用到的變量會保存相關信息。在此之后,DOM文檔被打開,一個“句柄(handle)”會被返回到sp_xml_preparedocument調用的第一參數里。

這個調用的第二個參數是用于新DOM文檔的XML源文件。這個“句柄”是在進行OPENXML調用的時候用來從DOM里查詢信息的。OPENXML調用的第二個參數是父節點的一個Xpath映射,這些父節點包含有要被執行的數據。
 


第三個參數(2)指明,以元素為中心的映射會被使用。WITH子句為被剖析的數據提供了數據列集(rowset)格式,sp_xml_removedocument調用會刪掉DOM文檔的源文件。

在下面這個例子里,我會傳遞一系列用戶ID,用以刪除多個數據列。下面就是XML字符串的內容:


<root><Customer><customerid>1</customerid></Customer><Customer><customerid>
2</customerid></Customer><Customer><customerid>3</customerid></Customer>
</root>

 

相應的存儲過程看起來就像下面這樣:
. . .

EXEC sp_xml_preparedocument @xml_id OUTPUT, @xmldata, ''

DELETE FROM Customer WHERE Customer.tblID IN (SELECT customerid FROM
 OPENXML(@xmldata_id, '//Customer', 2) WITH (customeridint))

. . .


有了這個存儲過程就不再需要創建一個冗長的SQL查詢字符串,用以在ADO里傳遞或者多次調用一個存儲過程了。這也會消除多次調用對網絡流量所造成的影響。

正如你能夠看到的,微軟的SQL 2000讓整個過程稍稍簡單了一點。要記住,這一方法的不足之處在于:在SQL 2000進行XML任務的時候,將XML作為一個參數發送會被限制到8,000字符。和以往一樣,不要忽視了精心策劃的好處。

訪問MSDN庫能夠獲得更多關于OPENXML、sp_xml_preparedocument以及sp_xml_removedocument的信息。


 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚洲一区二区三区视频免费 | 精品国产91久久久久久久 | 干一夜综合 | www.91在线观看 | 成年人免费视频播放 | 成人性生活视频在线观看 | 国产精品久久久久久久久久尿 | 国产精品久久久久久久久久妇女 | 亚洲网站在线观看 | 国产午夜亚洲精品午夜鲁丝片 | wwwav国产| 国产亚洲精品综合一区 | 日韩三级伦理在线观看 | 亚欧在线免费观看 | 日韩视频在线视频 | 狠狠操夜夜爱 | 精品久久中文网址 | 91精品国产91| 日韩视频一区在线 | 久国产| 毛片大全免费 | 欧美成人免费香蕉 | 亚洲人成免费 | 国产羞羞视频 | 国产免费一区二区三区视频 | 日韩 综合 | 国产一有一级毛片视频 | 日日噜噜噜夜夜狠狠久久蜜桃 | 国产精品亚洲综合一区二区三区 | 搜一级毛片 | 污版视频在线观看 | a免费毛片 | 久久久久久久久久久一区 | 亚洲尻逼视频 | 国产精品久久久久久久娇妻 | xxxxxx视频| 日韩欧美精品电影 | 久久久久久久久久久综合 | 看91视频 | 国产亚洲精品久久久久久网站 | 天天色图片 |