通过HTTP访问SQL Server 2000数据库
Microsoft SQL Server 2000的新特性之一就是支持XML,所以用户可以通过HTTP方式直接访问具备XML功能的SQL Server2000数据库。下面介绍实现方法。系统环境:Windows2000 Server(包含IIS+ MS SQL Server2000数据库:SQL Server2000附带的经典数据库样本:NorthWind一、配置IISSQL Server virtual domains1.新建文件目录打开Windows资源管理器,在Inetpubwwwroot下新建目录northwindC:Inetpubwwwroot orthwindnorthwind目录下再新建2个子目录:templateschemaC:Inetpubwwwroot wind emplate,用于放置XML模版;C:InetpubWwwroot windschema,用于放置schema文件。2.映射IIS的虚拟目录在SQL程序组中选择“Configure SQL XML Support in IIS”,在默认站点下选择新建”->“虚拟路径;然后进行五步标准配置。(1)在sql数据库迁移另一个硬盘“General”页中,输入虚拟路径名称“northwind”并映射至实际硬盘路径,结果见图。
2)在“Security”页中,选择相应的登陆帐号和口令。本例中使用系统帐号sa,结果见图。
3)在“Data Source”页中,选择SQL Server名称或IP地址,并选择数据库。4)在“Settings”页中,分别选中允许URL查询允许模版查询允许XPath”允许Post”,结果见图。
5)在“Virtual Names”页中,分别定义TemplateSchemaDbobject,并指定实际硬盘路径。然后,确定并关闭窗口。
二、用URL方式执行查询和存储过程;至此,我们已经设置好SQLIIS,下面开始精彩的访问历程。先在IE浏览器中键入以下地址:172.24.2.98/northwind?sql=select+*+from+customers+for+xml+auto&root=root得到结果如图所示。其中,“northwind”为虚拟路径名;“select+*+from+customers”SQL查询语句“Select * from c
ustomers”“for XML”语句表示输出的数据格式为XML文档,而非标准数据行。“root”参数表示为顶层元素。RAWAUTOEXPLICIT三种XML模式分别为:RAW在每条记录前加一个简单的标识,如“<rowCustomerID="ALFKI"…”AUTO则会在每条记录前加入数据表的名称,如“<CustomersCustomerID="ALFKI"”EXPLICIT则可用于定义XML的树形结构。初试成功后,我们再尝试使用URL地址执行存储过程(Stored Procedure)。先在SQL Query Analyzer中新建一个名为CategoryInfo的存储过程;代码如下:CREATE PROCEDURE CategoryInfoASSELECT CategoryName, Description FROM CategoriesFOR XML AUTO
通过地址172.24.2.98/northwind?sql=execute+categoryinfo&root=root即可执行存储过程。
三、访问XML模版文件此外,网站开发人员还可以定义XML的模版,定义查询条件和结果输出格式:如,在wwwroot orthwind emplate目录下生成一个XML文档l,其中包含一个查询语句,代码如下:<root xmlns:sql="urn:schemas-microsoft-com:xml-sql" >  <sql:query>    SELECT *    FROM Customers AS Customer    FOR XML auto  </sql:query></root>通过地址172.24.2.98/northwind/l访问,得到结果。结合Exten
sible Stylesheet Language (XSL)可以格式化查询结果,使报表更加美观。通过以上介绍,你也许已经对SQL2000XML有了初步的了解。仔细阅读SQL的帮助文件和MSDN.COM会对你深入掌握SQL2000有着更大的帮助。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。