使用Microsoft SQL Server 2000的XML查询

莫Tm愁_李政

莫Tm愁_李政

2016-01-29 16:02

使用Microsoft SQL Server 2000的XML查询,使用Microsoft SQL Server 2000的XML查询
由于XML本身的诸多优点,XML技术已被广泛的使用,目前的好多软件技术同XML紧密相关,比如微软的。net 平台对xml提供了强大的支持,提供System.Xml以及其子命名空间下的类型来操作xml.Ado.net通过核心类型DataSet出色的把关系型数据库同xml进行了紧密集成。由于平常许多开发人员使用。net 来操作Sql server的到数据集后再转换成xml,所以往往忽略Transact-SQL查询生成XML数据的强大功能。对于一些项目使用XML查询直接通过SQL生成xml会来的更为简便,所以我通过在实际项目中的使用和查阅一些资料写成一个知识点,一是温故而知新,二是对于一些开发者刚好需要这方面的技术而还没有找到比较快捷的学习方式提供一条途径。

  在SQL SERVER 2000中查询生成XML的语法表达式比较简洁,整个语法如下:

  SELECT <;select_list

  FROM <;table_source

  WHERE <;search_condition

  FOR XML AUTO | RAW | EXPLICIT [,XMLDATA ] [,ELEMENTS] [,BINARY BASE64]

  下面我将以Northwind数据库来演示上面的表达式中所包含的各项功能,下面的查询语句和返回结果都通过SQL SERVER 2000查询分析器来执行和得到。

  一。 使用AUTO模式

  该模式我认为在生成单表xml数据方面是用得最多的,能满足一般的需要。先来看他的简单查询。

  1.简单查询

  查询语句:

  SELECT CategoryID,

  CategoryName

  FROM Categories

  WHERE CategoryID <; 3 FOR XML AUTO

  返回结果:

  <;Categories CategoryID="1" CategoryName="Beverages"/

  <;Categories CategoryID="2" CategoryName="Condiments"/

  也可以使用别名,

  查询语句:

  SELECT CategoryID AS ID,

  CategoryName,

  GetDate() as CurrDate

  FROM Categories MyTable

  WHERE CategoryID <; 3 FOR XML AUTO

  返回结果:

  <;MyTable ID="1" CategoryName="Beverages" CurrDate="2005-06-24T11:09:52.937"/

  <;MyTable ID="2" CategoryName="Condiments" CurrDate="2005-06-24T11:09:52.937"/

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/sqlserver/)

  2.连接查询

  以两个表为例,

  查询语句:

  SELECT Categories.CategoryID,

  Categories.CategoryName,

  ProductID,

  ProductName

  FROM Categories

  JOIN Products ON Categories.CategoryID = Products.CategoryID AND ProductID <;5

  WHERE Categories.CategoryID <; 3 FOR XML AUTO

  返回结果:

  <;Categories CategoryID="1" CategoryName="Beverages"

  <;Products ProductID="1" ProductName="Chai"/

  <;/Categories

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/sqlserver/)

  <;Categories CategoryID="2" CategoryName="Condiments"

  <;Products ProductID="2" ProductName="Chang"/

  <;/Categories

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/sqlserver/)

  可以看到表连接查询可以生成分层次的Xml,不过需要注意的是SELECT子句中的父表的列要排在子表的列的前面,否则会出现你不想看到的结果,如:

  查询语句:

  SELECT ProductID,Categories.CategoryID,Categories.CategoryName,ProductName

  FROM Categories

  JOIN Products ON Categories.CategoryID = Products.CategoryIDand ProductID <;5

  WHERE Categories.CategoryID <;3FOR XML AUTO

  返回结果:

  <;Products ProductID="1" ProductName="Chai"

  <;Categories CategoryID="1" CategoryName="Beverages"/

  <;/Products

  <;Products ProductID="2" ProductName="Chang"

  <;Categories CategoryID="1" CategoryName="Beverages"/

  <;/Products

  <;Products ProductID="3" ProductName="Aniseed Syrup"

  <;Categories CategoryID="2" CategoryName="Condiments"/

  <;/Products

  <;Products ProductID="4" ProductName="Chef Anton&apos;s Cajun Seasoning"

  <;Categories CategoryID="2" CategoryName="Condiments"/

  <;/Products

  3.使用ELEMENTS选项

展开更多 50%)
分享

猜你喜欢

使用Microsoft SQL Server 2000的XML查询

SQLServer
使用Microsoft SQL Server 2000的XML查询

Microsoft SQL Server 2000 中查询优化器使用的统计(2)

编程语言 网络编程
Microsoft SQL Server 2000 中查询优化器使用的统计(2)

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

使用SQL Server 2005 FOR XML嵌套查询

编程语言 网络编程
使用SQL Server 2005 FOR XML嵌套查询

XML文件导入SQL Server 2000

SQLServer
XML文件导入SQL Server 2000

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

在 Microsoft SQL Server 2000 数据仓库中使用分区

编程语言 网络编程
在 Microsoft SQL Server 2000 数据仓库中使用分区

将XML文件导入SQL Server 2000

SQLServer
将XML文件导入SQL Server 2000

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

建立一个安全稳定的局域网 我们需做什么

建立一个安全稳定的局域网 我们需做什么

Photoshop教程:手绘逼真的中式早餐豆浆油条

Photoshop教程:手绘逼真的中式早餐豆浆油条
下拉加载更多内容 ↓