1. 1.         1、@XML 为数据传入的XML格式
  2. 2.         root 为根目录
  3. 3.         <A>为对应需要插入的表,详见一对多或者多对多的xml格式
  4. 4.         多对多是<ID> 为该条数据对应的从表的唯一标识,可以为其他名称的字段。

如:<Customer><ID>1</ID></ Customer >

<CustomerBranch><ID>1</ID></CustomerBranch>

  1. 5.         注意案例存储过程只定义了2个参数,可以根据自己的具体需求增加参数。

1.6  EXECUTE sp_xml_preparedocument 为sql自带的处理xml函数。

一、         对单表(单条或者多条)的操作。

declare @XML xml

set @XML=N'<root>

<A>

<ID>1</ID>

<name>test1</name>

</A>

<A>

<ID>2</ID>

<name>test2</name>

</A>

</root>'

Insert into Temp(ID,Name)

select S.value('(ID)[1]','int') as ID,

S.value('(name)[1]','nvarchar') as name,

from @ XML.nodes('/root/A')  T(S)

注意:A 为表名 ID,Name为此表对应的字段名

二、         对多表(一对多)的操作

declare @CustomerID int

declare @XML xml

set @XML=N'<root>

<Customer>

<CustomerName>深圳大展</CustomerName>

<CustomerTypeID>116</CustomerTypeID>

</Customer>

<CustomerBranch>

<BranchID>2</BranchID>

<AreaID>6</AreaID>

</CustomerBranch>

<CustomerBranch>

<BranchID>2</BranchID>

<AreaID>6</AreaID>

</CustomerBranch>

</root>'

Insert into Customer(CustomerName,CustomerTypeID)

select S.value('(CustomerName)[1]','nvarchar') as CustomerName,

S.value('(CustomerTypeID)[1]','int') as CustomerTypeID

from @XML.nodes('/root/Customer')  T(S)

set @CustomerID =@@IDENTITY

insert into CustomerBranch(CustomerID,AreaID,BranchID)

select @CustomerID , S.value('(AreaID)[1]','int') as AreaID,

S.value('(BranchID)[1]','int') as BranchID

from @XML.nodes('/root/CustomerBranch')  T(S)

三、         对多表(多对多)的操作

 

declare @CustomerID int

declare @Count int

declare @Error int

declare @XML xml

set @XML=N'<root>

<Customer>

<ID>1</ID>

<CustomerName>深圳大展</CustomerName>

<CustomerTypeID>116</CustomerTypeID>

</Customer>

<Customer>

<ID>2</ID>

<CustomerName>艾默生</CustomerName>

<CustomerTypeID>116</CustomerTypeID>

</Customer>

<CustomerBranch>

<ID>1</ID>

<BranchID>2</BranchID>

<AreaID>6</AreaID>

</CustomerBranch>

<CustomerBranch>

<ID>2</ID>

<BranchID>4</BranchID>

<AreaID>6</AreaID>

</CustomerBranch>

<CustomerBranch>

<ID>2</ID>

<BranchID>2</BranchID>

<AreaID>3</AreaID>

</CustomerBranch>

</root>'

select @Count =MAX(RowNumber)

from ( select ROW_NUMBER() OVER (ORDER BY S.value('(ID)[1]','int') ) AS RowNumber

from  @XML.nodes('/root/Customer')  T(S)) as m

while(@Count>0)

begin

insert into Customer(CustomerName,CustomerTypeID)

select CustomerName,CustomerTypeID

from (

select ROW_NUMBER() OVER (ORDER BY  S.value('(ID)[1]','int') desc ) ASRowNumber,

S.value('(CustomerName)[1]','nvarchar(200)') as CustomerName,

S.value('(CustomerTypeID)[1]','int') as CustomerTypeID

from @XML.nodes('/root/Customer')  T(S)

) as m  where RowNumber=@Count

set @CustomerID=@@IDENTITY

insert into CustomerBranch(CustomerID,AreaID,BranchID)

select @CustomerID , S.value('(AreaID)[1]','int') as AreaID,

S.value('(BranchID)[1]','int') as BranchID

from @XML.nodes('/root/CustomerBranch')  T(S)

where S.value('(ID)[1]','int') =( select ID

from ( select ROW_NUMBER()OVER (ORDER BY  S.value('(ID)[1]','int') desc ) AS RowNumber,

S.value('(ID)[1]','int') as ID

from@XML.nodes('/root/Customer')  T(S)

) as m whereRowNumber=@Count)

set @Count=@Count-1

end

四、         批量更新数据

                declare @XML xml

set @XML=N'<root>

<Customer>

<CustomerID>1</CustomerID>

<CustomerName>大客户_TestXML2</CustomerName>

</Customer>

<Customer>

<CustomerID>2</CustomerID>

<CustomerName>大客户_TestXML1</CustomerName>

</Customer>

</root>'

update Customer

set CustomerName =m.value('(CustomerName)[1]','nvarchar(200)')

from @XML.nodes('/root/Customer') T(m)

where CustomerID=m.value('(CustomerID)[1]','int')

五、具体存储过程案例(一对多或者多对多的根据案例代码放入到对应的事务即可)

--测试存储过程

ALTER PROCEDURE [dbo].[AddXML]

(

@xmlstr XML,

@ProcMessageCode int output

)

AS

BEGIN

set nocount on

set xact_abort on

--定义中间变量

declare @error int

--设置初始值

set @error = 0

--开始事务处理

begin tran tranAddXML

insert into tt

select

S.value('(ID)[1]','int') as ID,

S.value('(name)[1]','nvarchar(10)') as name,

S.value('(age)[1]','int') as age

from @xmlstr.nodes('/root/tt') T(S)

--记录错误

set @error = @error + @@ERROR

if @error <> 0

begin

--回滚事务

rollback tran tranAddXML

--返回保存失败

set @ProcMessageCode = '10020115'

end

else

begin

--提交事务

commit tran tranAddXML

--返回保存成功

set @ProcMessageCode = '10030114'

end

set xact_abort off

set nocount off

END

Sql 解析XML 解决方案的更多相关文章

  1. Sql 解析XML 解决方案参考

    1.定义存储过程 -- =============================================-- Author: <Author,,Name>-- Create da ...

  2. sql解析xml

    我们有时候需要在sql中解析xml,xml解析sql实例如下:  DECLARE @params xml  DECLARE @customparams xml = null  -- 0.解析输入参数 ...

  3. SQL解析XML文件

    DECLARE @idoc int DECLARE @doc varchar(max) SET @doc ='<?xml version="1.0" encoding=&qu ...

  4. SQL 存储过程 解析XML

    第一种说明: 我看过这样一篇文章,如下 在SQL   Server2005中,微软延续了   2000中一个特性(即支持XML类型的数据),并加强了对XML   数据列.XML变量以及XML索引的支持 ...

  5. SQL Server XML数据解析

    --5.读取XML --下面为多种方法从XML中读取EMAIL DECLARE @x XML SELECT @x = ' <People> <dongsheng> <In ...

  6. SQL Server解析XML数据的方法详解

    --下面为多种方法从XML中读取EMAIL DECLARE @x XML SELECT @x = ' <People> <dongsheng> <Info Name=&q ...

  7. Oracle使用Sql把XML解析成表(Table)的方法

    SELECT * FROM XMLTABLE('$B/DEAL_BASIC/USER_DEAL_INFO' PASSING XMLTYPE('<?xml version="1.0&qu ...

  8. 《Mybatis 手撸专栏》第9章:细化XML语句构建器,完善静态SQL解析

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 你只是在解释过程,而他是在阐述高度! 如果不是长时间的沉淀.积累和储备,我一定也没有 ...

  9. Objective-C ,ios,iphone开发基础:使用GDataXML解析XML文档,(libxml/tree.h not found 错误解决方案)

    使用GDataXML解析XML文档 在IOS平台上进行XML文档的解析有很多种方法,在SDK里面有自带的解析方法,但是大多情况下都倾向于用第三方的库,原因是解析效率更高.使用上更方便 这里主要介绍一下 ...

随机推荐

  1. 【题解】[USACO12JAN]Video Game G

    第一道\(AC\)自动机\(+DP.\) 首先,一个自动机上\(DP\)的套路是设\(dp[i][j]\)表示长度为\(i\)匹配到\(j\)节点的最优得分. 那么,由于我们已经建好了\(Trie\) ...

  2. 【题解】SP10570 【LONGCS - Longest Common Substring】

    \(\color{Red}{Link}\) \(\text{Solution:}\) 还是\(\text{Suffix Tree.}\) 根据\(\color{Blue}{Link}\)我们可以得到一 ...

  3. win10下安装使用Docker:Docker for Windows

    一.下载win10下安装docker和桌面管理的工具: 下载地址:Docker for Windows 安装软件学习地址:https://www.runoob.com/docker/docker-tu ...

  4. [源码阅读] 阿里SOFA服务注册中心MetaServer(3)

    [源码阅读] 阿里SOFA服务注册中心MetaServer(3) 目录 [源码阅读] 阿里SOFA服务注册中心MetaServer(3) 0x00 摘要 0x01 概念 1.1 分布式一致性 1.2 ...

  5. day52 Pyhton 前端03

    内容回顾 块级标签: div p h 列表:ol;ul;dl 表格:table 行内标签: span a i/em b/strong u/del 行内块: input textarea img 其他: ...

  6. .NET Core+MongoDB集群搭建与实战

    目录 安装 MongoDB apt 直接安装(方法1) apt 仓库安装(方法2) 方法1.2启动 MongoDB 通过二进制包安装(方法3) 安装依赖 deb 安装 MongoDB tgz 安装 M ...

  7. go读取excel表格数据

    go读取excel表格数据 使用工具 github.com/Luxurioust/excelize 百度到的都是使用这个 实际上已经改名了 github.com/360EntSecGroup-Skyl ...

  8. nginx安全:配置ssl证书(https证书)

    一,配置https证书的意义 https协议是由SSL+http协议构建的安全协议,支持加密传输和身份认证, 安全性比http要更好,因为数据的加密传输,更能保证数据的安全性和完整性 例如:不使用ht ...

  9. 【应用服务 App Service】Azure 应用服务测试网络访问其他域名及请求超时限制(4分钟 ≈ 230秒)

    测试App Service是否可以访问其他DNS 当应用服务(Azure App Service)创建完成后,想通过ping命令来查看是否可以访问其他站点或解析DNS,但是发现ping命令无法使用.这 ...

  10. c++ qsort的使用

    c++ qsort的使用 qsort函数定义在头文件algorithm中,使用时需要include该头文件 void qsort (void* base, size_t num, size_t siz ...