45IT.COM- 电脑学习从此开始!
DIY硬件教程攒机经验装机配置
设计Photoshop网页设计特效
系统注册表DOS系统命令其它
存储主板显卡外设键鼠内存
维修显卡CPU内存打印机
WinXPVistaWin7unix/linux
CPU光驱电源/散热显示器其它
修技主板硬盘键鼠显示器光驱
办公ExcelWordPowerPointWPS
编程数据库CSS脚本PHP
网络局域网QQ服务器
软件网络系统图像安全
页面导航: 首页 > 设计学院 > 网络编程 > 数据库 >

SQL 2005: 把XML格式字串转换成表格

电脑软硬件应用网 45IT.COM 时间:2012-03-11 17:51 作者:佚名

有的人用字串分隔技巧送出一个很长的字串,到了后端资料库时再想办法分割字串。我则是使用送出xml格式字串的方式,让后端DB转换成表格之后就可以做多种运用了。

这次的例子如下:

<Data>
<Item userName="Kenny" age="18" level="9" />
<Item userName="DS" age="180" level="99" />
<Item userName="BL" age="180" level="99" />
.....
</Data>

后端的Stored Procedures写成这样:

ALTER PROCEDURE [dbo].[TestXmlSproc]
@data xml
AS
BEGIN

SET NOCOUNT ON;

Declare @table Table (
rowID int identity,
userName varchar(20),
age int,
level int
)

Insert Into @table
Select Tbl.Col.value('@userName', 'varchar(20)'),
Tbl.Col.value('@age', 'int'),
Tbl.Col.value('@level', 'int')
From @data.nodes('//Data/Item') Tbl(Col)

写下来你就可以自由运用@table这个暂存资料表了。下面是我利用迴圈做更进阶的使用

 

ALTER PROCEDURE [dbo].[TestXmlSproc]
@data xml  --接收传入的xml格式字串
AS
BEGIN

SET NOCOUNT ON;

Declare    @table Table (
  rowID int identity,
  userName varchar(20),
  age int,
  level int)
Declare    @intRowCounts int,
  @intRowIndex int,
  @intNewValue int,
  @intOriginalValue int

Set  @intRowIndex = 1

--把xml格式字串转成资料表
Insert    Into @table
Select    Tbl.Col.value('@userName', 'varchar(20)'),
  Tbl.Col.value('@age', 'int'),
  Tbl.Col.value('@level', 'int')
From  @data.nodes('//Data/Item') Tbl(Col)

--取得total的row数量
Select    @intRowCounts = Count(RowId)
From  @table

While (@intRowIndex <= @intRowCounts)
Begin
    --取得新输入的数值
    Select    @intNewValue = level
    From  @table
    Where    rowID = @intRowIndex

    --取得原始的数值
    Select    @intOriginalValue = level
    From  Member
    Where    userName Like (
        Select    userName
        From     @table
        Where    rowID = @intRowIndex)

    --如果数值有变动则更新数值
    If (@intOriginalValue != @intNewValue)
    Begin
    Update    Member
    Set  level = @intNewValue
    Where    userName Like (
        Select    userName
        From  @table
        Where    rowID = @intRowIndex)
    End

    Set    @intNewValue = 0
    Set    @intOriginalValue = 0

    --记得更新index
    Set    @int_RowIndex = @int_RowIndex + 1
End

顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
无法在这个位置找到: baidushare.htm
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
验证码:点击我更换图片
推荐知识