SQL Server数据库对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简介

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/228283.html<

(0)
运维的头像运维
上一篇2025-04-18 05:49
下一篇 2025-04-18 05:51

相关推荐

  • hosteons独立服务器测评不限流量实测数据与性能表现怎么样?

    Hosteons 独立服务器在 2026 年实测中展现出极高的性价比,其不限流量策略配合高性能硬件,是处理高并发与大数据传输场景下的理想选择,尤其适合预算敏感型中小企业及海外业务拓展需求,核心性能实测与硬件架构解析在 2026 年云计算基础设施全面向 ARM 与高主频 Intel 混合架构转型的背景下,Host……

    2026-05-02
    0
  • ftpitVPS测评,实测体验,ftpitVPS怎么样,ftpitVPS好用吗

    ftpitVPS 在 2026 年依然具备极高的性价比,尤其适合预算有限但追求稳定性的中小企业及开发者,其核心优势在于价格极具竞争力且网络线路优化明显,是入门级云服务器的优选方案,随着云计算市场在 2026 年的深度洗牌,用户对于 VPS(虚拟专用服务器)的选型逻辑已从单纯追求“低价”转向“性能价格比”与“网络……

    2026-05-02
    0
  • hostsolutionsVPS测评好用吗?抗投诉建站实测数据与性能表现

    HostSolutions VPS 在 2026 年依然是抗投诉能力与性价比兼顾的优选方案,尤其适合需要快速部署且对海外合规性有严格要求的独立站与小型企业用户,在 2026 年云计算市场趋于饱和的背景下,选择 VPS 服务商不再仅看价格,更需考量其网络稳定性、抗攻击能力以及合规策略,HostSolutions……

    2026-05-02
    0
  • RapidDediVPS测评,实测体验,RapidDediVPS怎么样,RapidDediVPS评测

    RapidDediVPS 在 2026 年已具备企业级高防能力,其性价比在亚洲节点中极具竞争力,尤其适合需要跨境业务加速及高并发处理的开发者,是RapidDediVPS 测评中值得推荐的优选方案,在 2026 年云计算基础设施全面向边缘计算与 AI 原生架构转型的背景下,RapidDediVPS 凭借其实体机独……

    2026-05-02
    0
  • SSDBlaze独立服务器测评多少钱?SSDBlaze独立服务器测评真实价格

    SSDBlaze 独立服务器在 2026 年 69 美元/月价位段,凭借基于 AMD EPYC 9004 系列的算力优势与低延迟网络架构,成为中小规模高并发业务场景下性价比极高的选择,但需针对特定地域优化网络路由,在 2026 年云计算市场深度调整期,企业级用户对“独立服务器推荐”的决策逻辑已从单纯追求低价转向……

    2026-05-02
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注