分享
 
 
 

深入探讨SQL Server 2000对XML的支持(一)

王朝mssql·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

我们可以很简单的使用ADO访问数据库中的数据,但是,假如我们想把从数据库中检索得到的数据以XML的格式显示出来的话,就要费点神了,当然,我们可以去找一些现成的应用程序或者是把现有的存储过程修改一下,来完成这个想法。

虽说ADO2.5宣称支持XML,但是它仍需要一个额外的层来处理把数据转化成XML的过程。幸好有了SQL Server 2000,它宣称可以直接从数据库中取出数据,而不通过ADO2.5直接把数据以XML方式显示出来。这个功能极大的提高了构造分布式、数据集中的应用程序的性能,因为这个特性消除了不必要的代码层。

让我们看一看,为了支持XML,SQL Server 2000添加了什么新的特性:

1、能够使用 HTTP 访问 SQL Server。

2、支持 XDR(XML数据简化)架构并且能够指定对这些架构的 XPath 查询。

3、能够检索并写入 XML 数据:

使用 SELECT 语句和 FOR XML 子句检索 XML 数据。

使用 OPENXML 行集提供程序写入 XML 数据。

使用 XPath 查询语言检索 XML 数据。

4、增强了 Microsoft SQL Server 2000 OLE DB 提供程序 (SQLOLEDB),使得可以将 XML 文档设置为命令文本并以流的形式返回结果集。

可见,我们可以使用好几种方法使用SQL Server 2000来访问XML格式的数据:第一种,在 URL 中执行的查询可以直接访问 SQL Server 2000生成XML文档(也可以调用存储在Web服务器上的XML模版生成XML数据文件)。第二种,可以使用SELECT命令和FOR XML要害字,通过调用一个存储过程或是通过使用XPath查询来取得XML数据。SQL Server 2000 完全支持 XDR(XML数据简化)架构,具有映射XML元素和属性到表和字段中的功能。下面,我就探讨一下SQL Server 2000对XML的支持特性。

一、配置SQL Server 2000的IIS虚拟目录

在本文的开始,我想先谈一谈如何配置SQL Server 2000的IIS虚拟目录。SQL Server 2000 答应为IIS创建一个虚拟目录,用来直接访问一个SQL数据库中的数据。一旦在一台配置了IIS的计算机上安装了SQL Server 2000,就可以运行SQL Server 的 IIS 虚拟目录治理实用工具来配置SQL Server 2000的IIS虚拟目录。

好,让我们开始配置过程吧!

在"SQL Server 工具"程序组中单击"在 IIS 中配置 SQL XML 支持",这时就会出现一个与IIS治理器相似的界面。展开服务器,选取默认的 Web 站点,点右键,在弹出的菜单中选取“新建”选项,然后单击"虚拟目录"命令。新虚拟目录的属性页将显示在屏幕上。在"新的虚拟目录属性"对话框的"常规"选项卡上,输入虚拟目录的名称,在本例中,请输入Northwind和物理目录路径(例如 C:InetpubWwwrootNorthwind,假设在 C:InetpubWwwroot 目录中已创建了 Northwind子目录),当然我们也可以使用“浏览”按钮选择目录。在“安全性”选项卡上,填入有效的 SQL Server 登录信息,在进入下一个选项卡时,它将要求你确认刚才输入的密码。在“数据源”选项卡上,在“SQL Server”框中输入服务器的名称,在“数据库”框中,输入 Northwind 作为默认数据库的名称。在"设置"选项卡上,你可以选择“答应 URL 查询”、“答应模板查询”、“答应 XPath”和“答应 POST”选项。

在构建一个应用程序时,你不但要考虑到能够访问到SQL Server数据库,要有足够的安全级别以保证你的数据的安全性。在“虚拟名称”选项卡上,你可以更具自己的需要选择新建模板类型(template)、架构类型(schema)和模板和架构类型(dbonject),并创建它们的路径。好,我们这样就创建了虚拟目录 Northwind。默认情况下,使用该虚拟目录对 Northwind 数据库执行指定的查询。你一定迫不及待的吸纳高看看执行SQL的结果是什么样的了吧?好,让我们在浏览器中输入http://localhost/northwind?sql=SELECT * FROM CUSTOMERS FOR XML AUTO&root=root,试验一下吧!

我们还可以编程来实现配置SQL Server 2000的IIS虚拟目录,请见下面的代码:

Set ObjXML = CreateObject("SQLVDir.SQLVDirControl")

ObjXML.Connect 'Connect to the local computer and Web site "1"

Set ObjVDirs = ObjXML.SQLVDirs

Set ObjVDir = ObjVDirs.AddVirtualDirectory("Northwind")

ObjVDir.PhysicalPath = "C:Inetpubwwwroot

orthwind"

ObjVDir.UserName = "wayne" 'SQL Server login

ObjVDir.PassWord = "" 'SQL Server Password

ObjVDir.DatabaseName = "Northwind"

objVDir.AllowFlags = 73

Set objVNames = objVDir.VirtualNames

objVNames.AddVirtualName "dbobject", 1, ""

objVNames.AddVirtualName "schema", 2,"C:Inetpubwwwroot

orthwindschema"

objVNames.AddVirtualName "template", 4 , "C:Inetpubwwwroot

orthwindemplate"

objXML.Disconnect

msgbox "Done."

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有