当前位置:首页 >探索 >SQL Server数据库对XML节点和XML块的操作实例解析 希望能够对您有所帮助

SQL Server数据库对XML节点和XML块的操作实例解析 希望能够对您有所帮助

2024-06-29 10:12:58 [百科] 来源:避面尹邢网

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

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

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

1. 检查XML节点是数实例否存在

SQL Server数据库对XML节点和XML块的操作实例解析 希望能够对您有所帮助

 

SQL Server数据库对XML节点和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 

 

SQL Server数据库对XML节点和XML块的操作实例解析 希望能够对您有所帮助

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简介
责任编辑:赵鹏 来源: 博客园 SQL Server数据库XML节点XML块

(责任编辑:综合)

    推荐文章
    热点阅读