SQL Server数据库对XML节点和XML块的操作实例解析

数据库 SQL Server
本文我们主要介绍了SQL Server数据库对XML的操作,包括对XML节点的操作和对XML块的操作等,希望能够对您有所帮助。

SQL Server数据库对XML是如何操作的呢?本文我们主要就介绍这部分内容,包括对XML节点的操作和对XML块的操作等,接下来就让我们一起来了解一下这部分内容。

1. 检查XML节点是否存在

 

  1. SELECT xmlContent.exist('/Samples/Sample'),  
  2.     * FROM xmlTable  
  3. WHERE xmlContent.exist('/Samples/Sample') = 1  
  4.  
  5. SELECT xmlContent.exist('/Samples//Name'),  
  6.     * FROM xmlTable  
  7. WHERE xmlContent.exist('/Samples//Name') = 1 

 

2.  检查XML节点值是否存在

  1. SELECT TOP 100    *   
  2. FROM  xmlTable   
  3. WHERE xmlContent.exist('/Samples/Sample[Value=1]') = 1 

 

3.  获取某个XML节点的内容 (类似DOM的OutterXML)

  1. SELECT TOP 100   xmlContent.query('/Samples/Sample/Name'),   
  2.    *   
  3. FROM  xmlTable 

 

4.  获取指定XML块的内容 (类似DOM的innerText)

  1. SELECT TOP 100   xmlContent.value('(/Samples/Sample/Name)[1]', 'varchar(100)'),   
  2.    *   
  3. FROM  xmlTable 

附:做测试用的数据表和数据的生成SQL

-- 创建测试表

  1. CREATE TABLE [xmlTable](  
  2.     [xmlId] [int] IDENTITY(1,1) NOT NULL,  
  3.     [xmlName] [varchar](50) NOT NULL,  
  4.     [xmlContent] [xml] NOT NULL,  
  5.     [xmlDescr] [varchar](2000) NULL  

 

-- 初始化数据

  1. -- truncate table xmlTable  
  2. DECLARE @iRow int,  
  3.         @xmlContent xml,  
  4.         @xmlName varchar(50),  
  5.         @xmlId int  
  6. SET @iRow = 0 
  7. SELECT @xmlId = max(xmlid) from xmlTable  
  8. if(@xmlId is null)  
  9.     SET @xmlId = @iRow + 1  
  10. While @iRow < 5 
  11. BEGIN  
  12.     SET @xmlName = 'Sample' + Convert(varchar(10), @xmlId + @iRow)  
  13.     SET @xmlContent = '<Samples><Sample><Name>' + @xmlName+ '</Name><Value>'+ CONVERT(varchar(20), @xmlId + @iRow)   
  14.         + '</Value></Sample></Samples>'  
  15.     INSERT INTO [xmlTable]  
  16.            ([xmlName]  
  17.            ,[xmlContent]  
  18.            --,[xmlDescr]  
  19.            )  
  20.      VALUES  
  21.            (@xmlName  
  22.            ,@xmlContent  
  23.            --,<xmlDescr, varchar(2000),> 
  24.            )  
  25.       SET @iRow = @iRow + 1  
  26. END 

 

关于SQL Server数据库对XML节点和XML块的操作就介绍到这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

 

  1. SQL Server 2008 MDX学习笔记之理解元数组
  2. SQL Server数据库DataRelation的应用示例详解
  3. SQL Server 2005/2008中的CTE应用之递归查询
  4. SQL Server 2008数据库学习笔记之MDX查询示例
  5. SQL Server 2008原生的分层数据类型hierarchyid简介
责任编辑:赵鹏 来源: 博客园
相关推荐

2010-07-05 14:58:35

SQL Server数

2010-07-05 15:23:08

SQL Server数

2011-08-22 13:28:56

FOR XMLSQL Server

2011-08-22 09:55:30

SQL Server 排序

2011-08-04 11:26:18

XML文档数据库

2011-08-24 09:15:36

SQL Server数FOR XML AUT

2011-04-02 11:14:20

SQL Server数XML

2010-07-02 14:46:20

SQL Server数

2010-06-28 09:53:11

SQL Server数

2010-07-08 11:23:41

SQL Server还

2011-08-22 14:00:13

SQL Server 游标调用函数

2009-02-23 13:41:42

XML操作函数SQL Server

2009-10-23 10:08:29

SQL SERVER

2010-07-08 11:05:14

SQL Server数

2011-08-22 12:01:36

SQL Server代码优化

2009-02-04 17:36:11

ibmdwXML

2011-04-15 11:43:24

SQL Server

2009-09-09 14:40:15

C# XML解析

2011-08-18 10:36:24

SQL ServerISNULL函数

2011-08-25 13:10:44

SQL Server 设置自动编号字段
点赞
收藏

51CTO技术栈公众号