通行证: 用户 密码 域名空间  下载中心 社区论坛 信息公告 my小屋
联系我们
设为首页
加入收藏

 

qq,asp,php,jsp,xml,sql,.net,编程 程序 网页图象 建站经验 私服
首页 | 新闻资讯 | 编程开发 | 网页设计 | 图形图象 | 网络媒体 | 网站模板 | 数 据 库 | 投稿
论坛 | 操作系统 | 系统优化 | 网络安全 | 黑客技术 | 硬件学堂 | 硬件报价 | 服 务 器 | 地图
专题 | 应用软件 | 聊天通讯 | q q 专栏 | 建站经验 | 在线工具 | 站长club | 注 册 表 | 旧版
社会 | 游戏娱乐 | 设计欣赏 | 疑难解答 | 社区论坛 | 网络赚钱 | 网站地图 | 广告服务 | 服务
当前位置:首页>>编程开发>>sql专区>>正文 新版上线![旧版]
注:打开慢时请稍等
sql2000的xml功能将现有的存储过程代码作为web服务提供

http://www.iyit.net  日期:2006-5-3 19:18:55  来源:  点击:
参加讨论】 使用 .net 建立分布式应用程序
steve kirk 和 priya dhawan
microsoft developer network

摘要:本文介绍了如何使用 microsoft sql server 2000 的 xml 功能将现有的存储过程代码作为 web 服务提供。

目录
简介
sql server 2000 中的现有代码
总结

简介
microsoft® sql server™ 2000 的 xml 功能可以简化将现有代码作为 web 服务提供的任务。本文集中讨论了传入和传出 transact sql 代码的数据与 xml 消息(在 web 服务客户机和服务器之间使用)之间的转换。

评估现有代码是否适合于作为 web 服务提供时,本文讨论的数据转换问题并不是唯一需要考虑的问题。应考虑的其它因素包括状态模型、返回的数据大小、如何表示已经成功、如何返回错误信息、安全模型(包括访问控制、身份验证和加密)、执行模型(同步或异步)、如何分发代码,以及事务模型(com+ 事务或声明事务),等等。这些问题将在即将发表的体系结构主题(英文)文章中进行讨论。

sql server 2000 中的现有代码
sql server 2000 的 xml 功能简化了将现有 transact sql 代码作为 web 服务提供的过程。这依赖于 sql server 2000 中的两项 xml 功能:

对 transact sql 的扩展可将关系型数据转换为 xml,并且可以对传入的 xml 进行语法分析。
利用 isapi 模板功能,可将传入的 http 请求应用于 transact sql 代码,并且可以使用 xsl 样式表对传出的 xml 进行转换。只要可以使用 forxml 子句“选定”数据,sql server 就可以将 xml 返回到 xml 模板。
sql server 2000 xml 模板
sql server 2000 xml 模板以透明方式执行以下任务:

对传入的 http 请求进行解码
将参数应用于 transact sql 查询
执行查询
使用 xsl 转换传出的 xml
读数据
以下示例执行 isapi 模板中指定的 transact sql。如果必要,可将 http 请求传递到 transact sql 代码,并由该代码进行语法分析。根据模板中指定的 .xsl 文件,返回的 xml 将被转换为 soap 并返回给 web 服务的客户:

<root xmlns:sql="urn:schemas-microsoft-com:xml-sql" sql:xsl="bdadotnetwebservice3example1.xsl">
<orders>
<sql:query>
exec getordersxml
</sql:query>
</orders>
</root>
以下是模板中引用的 xsl 样式表,它将存储过程中的 xml 转换为 soap:

<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/xsl/transform"
xmlns:soap-env="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:m="some-uri">
<xsl:template match="/">
<soap-env:envelope>
<soap-env:body>
<m:bdadotnetwebservice3example1response >
<xsl:copy-of select="//orders"/>
</m:bdadotnetwebservice3example1response>
</soap-env:body>
</soap-env:envelope>
</xsl:template>
</xsl:stylesheet>
最后,以下存储过程代码在 transact sql select 语句中使用 for xml explicit 子句来返回 xml。“订单”和“订单详细信息”从单独的表中选择,然后合并到 xml 层次中:

/* 订单是父 xml 元素 */
select 1 as tag, null as parent,
orders.orderid as [order!1!orderid],
orders.orderstatus as [order!1!orderstatus],
orders.orderdate as [order!1!orderdate],
orders.subtotal as [order!1!subtotal],
orders.tax as [order!1!tax],
orders.shippinghandling as [order!1!shippinghandling],
orders.shiptoname as [order!1!shiptoname],
orders.shiptoaddressid as [order!1!shiptoaddressid],
null as [orderdetail!2!orderdetailid],
null as [orderdetail!2!orderid],
null as [orderdetail!2!itemid],
null as [orderdetail!2!unitprice],
null as [orderdetail!2!quantity]
from orders
union all
/* 订单详细信息是子 xml 元素 */
select 2 as tag, 1 as parent,
orders.orderid as [order!1!orderid],
null as [order!1!orderstatus],
null as [order!1!orderdate],
null as [order!1!subtotal],
null as [order!1!tax],
null as [order!1!shippinghandling],
null as [order!1!shiptoname],
null as [order!1!shiptoaddressid],
orderdetails.orderdetailid as [orderdetail!2!orderdetailid],
orderdetails.orderid as [orderdetail!2!orderid],
orderdetails.itemid as [orderdetail!2!itemid],
orderdetails.unitprice as [orderdetail!2!unitprice],
orderdetails.quantity as [orderdetail!2!quantity]
from orders, orderdetails
where orders.orderid = orderdetails.orderid
order by [order!1!orderid],[orderdetail!2!orderdetailid]
for xml explicit
写数据
以下示例中,通过 http 请求提供表示层次行数据的 xml,然后将其传递到 isapi 模板中指定的 transact sql 代码。在存储过程中对 xml 进行语法分析,并进行相应的写入操作:

create procedure insertorder
@order nvarchar(4000) = null,
@orderid int output
-
declare @hdoc int
declare @pkid int
begin transaction
/* 将 xml 载入文档以进行分析 */
exec sp_xml_preparedocument @hdoc output, @order
/* 插入订单标头 */
insert orders(customerid,
orderdate,
shiptoname,
shiptoaddressid,
orderstatus)
select *
from openxml(@hdoc, '/newdataset/orders')
with ( customerid int 'customerid',
orderdate datetime 'orderdate',
shiptoname nvarchar(40) 'shiptoname',
shiptoaddressid int 'shiptoaddressid',
orderstatus int 'orderstatus')
select @pkid = @@identity
/* 插入订单详细信息 */
insert orderdetails (orderid,
itemid,
unitprice,
quantity)
select @pkid as orderid, itemid, unitprice, quantity
from openxml(@hdoc, '/newdataset/details')
with ( itemid int 'itemid',
unitprice money 'unitprice',
quantity int 'quantity')
/* 指定输出参数的值 */
select @orderid = @pkid
commit transaction
/* 清除 xml 文档 */
exec sp_xml_removedocument @hdoc
总结
本文以及附带的示例介绍了有关数据转换的信息。通过数据转换,可以使用 sql server 2000 的 xml 功能将现有 transact sql 代码作为 web 服务提供。本文集中讨论了传入和传出 transact sql 代码的数据与 soap 消息(在 web 服务客户机和服务器之间使用)之间的转换。

这些解决方案的性能各异,并且受所传递的数据大小影响。在本系列后面的文章中,我们将对这些实现方法进行比较。

评估现有代码是否适合作为 web 服务时,接口只不过是应当考虑的诸多因素之一。应考虑的其它因素包括安全性(包括授权、身份验证和加密)、事务模型、状态模型、返回错误和结果的方式,以及代码是同步还是异步执行,等等。
编辑:黑鹰 [发送给好友] [打印本页] [关闭窗口] [返回顶部]
上一篇:使用 sql server 2000 将现有代码作为 web 服务提供
下一篇:也谈如何缩小sql server日志文件
转载请注明来源:www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。

 相关文章
第十七章 sql编程(二) 第十七章 sql编程(一) windows2000下安装apache php4 mysql  
windows 2000下安装php4及mysql大揭密  win2000 + php + mysql + tomcat + jsp 超级服务器apache+mysql+php+ssl之完全
超级服务器apache+mysql+php+ssl之完全 linux下快速安装“apache+php3+mysql” 如何集成linux、apache、php4、fastcgi
接触 solaris : 安装 apache + php + m linux服务器配置方案mysql(上) sql server 7.0与以前的版本相比,安全
设置proxy server和sql server实现互联 microsoft sql server 7.0安全问题     mysql安全性指南(3)(转)            
mysql安全性指南 (2)(转)            mysql安全性指南 (1)(转)            怎样才能限制sql server只能让指定的机
远程检测ms sql server账号安全性      模拟sql server的两个日期处理函数     用dbsql类加快开发mysql数据库程序的速
将access数据库移植到microsoft sql se microsoft sql server 7.0数据库设置与 microsoft sql server 7.0数据库升级转
最新更新 热点排行 推荐新闻
sql server 7.0与以前的版本相比,安全
设置proxy server和sql server实现互联
microsoft sql server 7.0安全问题   
mysql安全性指南(3)(转)           
mysql安全性指南 (2)(转)          
在frontpage 2000中插入flash动画
用frontpage 2000使图像“减肥”
提高frontpage 2002使用效率
用frontpage 2000创建网页动画
用frontpage 2000巧做样式表
用frontpage 2000制作鼠标光照特效
用frontpage轻松转换图片格式
frontpage10全透视教程(9)
frontpage10全透视教程(8)
frontpage10全透视教程(7)
sql server 7.0与以前的版本相比,安全
sql简明教程(6)
sql简明教程(5)
sql简明教程(4)
sql简明教程(3)
qq珊瑚虫外挂4.0版本发布!
多个广告位招商!
摄影后期系列一:1分钟为数码相片去红眼
qq挂机说明
asp进度条
photoshop通道抠图:给秀发飞扬的mm照
教您显示器亮度对比度的调节
新版上线,今日正式开通!!!
更多精彩图文广告等着您!
asp中使用sql语句教程
sql简明教程(1)
第二十章 开发delphi对象式数据管理功
sql简明教程(1)
vbscript和javascript互相调用 
jsp教程(四)-jsp actions的使用
操作系统被入侵后的修复过程
五一别忘电脑防毒 养成良好上网习惯
google对ie浏览器将捆绑搜索功能表担忧
新版上线,今日正式开通!!!
用photoshop创意图形“岁月”
摄影后期系列一:1分钟为数码相片去红眼

 友情链接
设置首 页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
copyrights © 2004-2006 iyit.net all rights reserved.
网站合作、广告联系qq:147007642、466949678
易特网络技术 点击这里给我发消息