设为首页 收藏本站
查看: 644|回复: 0

[经验分享] SQL Server2000的OpenXML特性

[复制链接]

尚未签到

发表于 2016-11-11 00:43:49 | 显示全部楼层 |阅读模式
SQL Server2000提供了OpenXML特性,我们可以很方便的用OpenXML特性来代替传统的行集结果,同样我们也可以使用定义好的XML文档作为输入的数据,这样也为我们的数据移植带来的巨大的便利。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />
同时,SQL Server2000中也提供了存储过程,用微软的话说,只有设计成存储过程,才算是”cleaner separation of code from the middle-tier”,这样做是很好的。应用程序访问数据库的数据并不是直接的与数据库表打交道,而是通过存储过程的运行来获取所需要的数据。这样的设计有一个好处就是,避免了频繁的表操作,而通过运行在服务器端的存储过程可以极大的提高运作效率和提升访问数据的速度,同时也很好的屏蔽了数据库表的逻辑,使得数据库访问变成了数据库提供的服务访问。
既然OpenXML和存储过程都可以提高SQL Server2000的性能,那么能否把这种技术结合起来了?答案是肯定的,下面我们就来看看怎么在存储过程中使用OpenXML.
以下是一个使用了OpenXML特性的存储过程:
*******************************************************************************

-------------------------------------------------------------------------------

-- upArchiveMsgInsertMsg

-------------------------------------------------------------------------------

/******************************************************************************

这是一个公文消息xml文档的实例


declare @xml varchar(8000)

SET @xml='<?xml version="1.0" encoding="gb2312" ?>

<ArchiveMsg

Title="jiangsuer" UserID="Admin" Author="湖北"

SendTime="<?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" /><date year="2001" day="1" month="1"><span lang="EN-US" style="FONT-SIZE: 9pt; COLOR: green; FONT-FAMILY: 新宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt">1/1/2001</span></date>" Department="mse"

AttachFile="hust"

ReceiveList="younther" Body="hustwelcome">

<MsgList UserID="Admin"/>

  <MsgList UserID="Anime"/>

<MsgList UserID="Tiger"/>

  </ArchiveMsg>'


exec upArchiveMsgInsertMsg @xml


*******************************************************************************/

//这个运行存储过程先在ArchiveMsg表中插入一条公文信息,并根据该条公文信息的MsgID和接受者列表,再在MsgList表插入每个接受者的UserID和MsgID,这些信息从xml中获取。


ALTER PROCEDURE upArchiveMsgInsertMsg

(

@xml varchar(8000)

)

AS

DECLARE @idoc int -- xml doc

DECLARE @MsgID int  -- new order

DECLARE @SendTime datetime

-- 解析XML文档

EXEC sp_xml_preparedocument @idoc output, @xml

SET NOCOUNT ON

DECLARE @CurrentError int

BEGIN TRANSACTION

  -- 开始更新数据的事务


SELECT @SendTime=SendTime

FROM OpenXML(@idoc, '/ArchiveMsg')

WITH ArchiveMsg


INSERT INTO ArchiveMsg(Title,UserID,Author,SendTime,Department,ReceiveList,Body,AttachFile)

SELECT Title,UserID,Author,SendTime,Department,ReceiveList,Body,AttachFile

FROM OpenXML(@idoc, '/ArchiveMsg')

WITH ArchiveMsg


  -- 错误检查

SELECT @CurrentError = @@Error

IF @CurrentError != 0

BEGIN

  GOTO ERROR_HANDLER

END

  

SELECT @MsgID=@@IDENTITY


INSERT INTO MsgList(MsgID,UserID,SendTime)

SELECT @MsgID,UserID,@SendTime

FROM OpenXML(@idoc, '/ArchiveMsg/MsgList')

  WITH (

  MsgID int,

UserID varchar(80),

SendTime datetime

)

-- 错误检查

  SELECT @CurrentError = @@Error


IF @CurrentError != 0

BEGIN

  GOTO ERROR_HANDLER

END


-- 事务结束

COMMIT TRANSACTION

SET NOCOUNT OFF

  -- 从内存中移除定义的XML文档

EXEC sp_xml_removedocument @idoc


RETURN 0


ERROR_HANDLER:

ROLLBACK TRANSACTION

SET NOCOUNT OFF

-- 从内存中移除定义的XML文档

EXEC sp_xml_removedocument @idoc

RETURN @CurrentError

*******************************************************************************
好了,存储过程就是这样了,我们得测试这个存储过程,测试函数代码如下:
首先我们得生成这个XML文档,为了简便起见,我们就用一个String变量来摸拟XML文档:
public string GetXmlString(ArchiveDetail myMsg,string[] useridList)

{

string xml="<?xml version=\"1.0\" encoding=\"gb2312\" ?>";

xml+="<ArchiveMsg ";

xml+="Title=\""+myMsg.Title+"\" ";

xml+="UserID=\""+myMsg.UserID+"\" ";

xml+="Author=\""+myMsg.Author+"\" ";

xml+="SendTime=\""+myMsg.SendTime.ToString()+"\" ";

xml+="Department=\""+myMsg.Department+"\" ";

xml+="AttachFile=\""+myMsg.AttachFilepath+"\" ";

xml+="ReceiveList=\""+myMsg.ReceiveList+"\" ";

xml+="Body=\""+myMsg.Body+"\">";

foreach(string i in useridList)

{

xml+="<MsgList UserID=\""+i+"\"/>";

}

xml+="</ArchiveMsg>";

return xml;

}
然后就是调用这个存储过程的函数:
public bool SendArchiveMsg(ArchiveDetail myMsg,string[] useridList)

{

string xml=this.GetXmlString(myMsg,useridList);

try

{

SqlParameter[] prams={ data.MakeInParam("@xml",SqlDbType.VarChar,8000,xml)  

  };

SqlConnection con = new
SqlConnection("server=127.0.0.1;uid=sa;pwd=sa;database=mydatabase");
  con.Open();


SqlCommand cmd = new SqlCommand("upArchiveMsgInsertMsg", con);

cmd.CommandType = CommandType.StoredProcedure;

foreach (SqlParameter parameter in prams)

  cmd.Parameters.Add(parameter);


cmd.Parameters.Add(

new SqlParameter("ReturnValue", SqlDbType.Int, 4,

ParameterDirection.ReturnValue, false, 0, 0,

string.Empty, DataRowVersion.Default, null));


cmd.ExecuteNonQuery();

con.Close();

int retval = (int)cmd.Parameters["ReturnValue"].Value;

if(retval==0)

return true;

else

return false;

}

catch(Exception ex)

{

Error.Log(ex.ToString());

return false;

}

}



在上述的代码中,代码量比较多,但是实际的处理过程其实比较简单,大致如下:

定义xml文

在存储过程中引入xml,利用sql server的open xml对之处理(具体就是几个与xml相关的函数)
在程序中调用存储过程

结束。

通过这样的方式我们就可以很方便的把xml及sql server结合起来应用。

当然sql server对xml的支持不仅在此,如果有留心的可以看到在IIS中也可以配置sqlxml,相关方面的内容,在后续的文章中会逐渐介绍,在文中有不详尽及不妥之处,还请各位网友批评指正。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-298441-1-1.html 上篇帖子: SQL语言快速入门123 下篇帖子: SQL Server2000中的IAM链
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表