一、前言
SQLServer 2005 引入了一种称为 XML 的本机数据类型。用户可以创建这样的表,它在关系列之外还有一个或多个 XML 类型的列;此外,还允许带有变量和参数。为了更好地支持 XML 模型特征(例如文档顺序和递归结构),XML 值以内部格式存储为大型二进制对象 (BLOB)。
用户将一个XML数据存入数据库的时候,可以使用这个XML的字符串,SQL Server会自动的将这个字符串转化为XML类型,并存储到数据库中。
随着SQL Server 对XML字段的支持,相应的,T-SQL语句也提供了大量对XML操作的功能来配合SQL Server中XML字段的使用。本文主要说明如何使用SQL语句对XML进行操作。
二、定义XML字段
在进行数据库的设计中,我们可以在表设计器中,很方便的将一个字段定义为XML类型。需要注意的是,XML字段不能用来作为主键或者索引键。同样,我们也可以使用SQL语句来创建使用XML字段的数据表,下面的语句创建一个名为“docs”的表,该表带有整型主键“pk”和非类型化的 XML 列“xCol”:
CREATE TABLE docs (pk INT PRIMARY KEY, xColXML not null)
XML类型除了在表中使用,还可以在存储过程、事务、函数等中出现。下面我们来完成我们对XML操作的第一步,使用SQL语句定义一个XML类型的数据,并为它赋值:
declare @xmlDoc xml; set @xmlDoc='<bookid="0001"> <title>C Program</title> <author>David</author> <price>21</price> </book>'
三、查询操作
在定义了一个XML类型的数据之后,我们最常用的就是查询操作,下面我们来介绍如何使用SQL语句来进行查询操作的。
在T-Sql中,提供了两个对XML类型数据进行查询的函数,分别是query(xquery)和value(xquery,dataType),其中,query(xquery)得到的是带有标签的数据,而
value(xquery,dataType)得到的则是标签的内容。接下类我们分别使用这两个函数来进行查询。
1、使用query(xquery) 查询
我们需要得到书的标题(title),使用query(xquery)来进行查询,查询语句为:
declare @xmlDoc xml; set @xmlDoc='<root> <bookid="0001"> <title>C#Program</title> <author>Jerry</author> <price>50</price> </book> <bookid="0002"> <title>JavaProgram</title> <author>Tom</author> <price>49</price> </book> </root>' select @xmlDoc.query('/root/book/title') select @xmlDoc.query('(//title)[2]') select @xmlDoc.query('(root/book[1]/title)') select @xmlDoc.query('(/root/book/title)[1]') select @xmlDoc.query('/root/book[position()<2]/title') declare @id varchar(max) = '0001' select @xmlDoc.query('/root/book[@id=sql:variable("@id")]/title')
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索xml
, query
, 类型
, 语句
, 字段
, XML操作
, xmlDoc
操作XML
sql server xml 操作、sqlserver xml、sql server xml、sql server xml 查询、sql server xml path,以便于您获取更多的相关知识。