2008年(8065)
分类: 服务器与存储
2008-04-26 08:26:52
创建多个带有不同参数的(stored procedure)来完成同一个任务总是一个很大的负担。利用
在本例里,为了更新一个Customer表格里的姓名字段,我会传递几个参数。为了获得customerid(身份列)和新的姓名字段,XML会被剖析。我传递给过程的XML字串就像下面的这样:
Inc.
要被创建的存储字段就像下面的这样:
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
第三个参数(2)指明,以元素为中心的映射会被使用。WITH子句为被剖析的数据提供了数据列集(rowset)格式,sp_xml_removedocument调用会删掉DOM文档的源文件。
2
相应的存储过程看起来就像下面这样:
. . .
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))
. . .
访问MSDN库能够获得更多关于OPENXML、sp_xml_preparedocument以及sp_xml_removedocument的信息。