当前位置:  编程技术>.net/c#/asp.net

C#怎样才能将XML文件导入SQL Server

    来源: 互联网  发布时间:2014-10-16

    本文导语:  问:怎样才能将XML文件导入SQL Server 2000? 答:将XML文件导入SQL Server有若干种方法,这里提供其中的3种: 大容量装载COM接口。如果需要将文档的实体和属性析取到关系表中,最快的方法就是使用SQL Server 2000 Extensible Markup Language...

问:怎样才能将XML文件导入SQL Server 2000?
答:将XML文件导入SQL Server有若干种方法,这里提供其中的3种:

大容量装载COM接口。如果需要将文档的实体和属性析取到关系表中,最快的方法就是使用SQL Server 2000 Extensible Markup Language 3.0 Service Pack 1(SQLXML 3.0 SP1)提供的大容量装载COM接口。大容量状态COM接口包含在SQLXML 3.0 SP1的免费下载中。

textcopy.exe命令行实用工具。如果不希望将文档的实体和属性析取到关系表中,您可以使用textcopy.exe命令行实用工具。Textcopy.exe是将文本和image数据类型从单一服务器行或列移入或移出的优秀工具。

数据转换服务(DTS)。如果XML文档很简单,您可以使用DTS将信息逐行析取到表中。这一方法要求您将XML文件定义为输入数据源,将数据库表定义为输出数据源,并编写ActiveX脚本剖析""方式的字符输入,以析取实体、属性及其值。

要导入的Xml文件:

代码如下:
 



32
新增执法机构页面
qqqqqq
组织机构
2009-07-31T00:00:00+08:00
王永刚


33
执法人员资格页面
大幅度放到大幅度放到
组织机构
2009-07-29T00:00:00+08:00
王永刚


34
111111
dfdwdd
qwqwq
2009-07-29T00:00:00+08:00
wyg


35
qq
fjdldldsss
qqqqqqq
2009-07-30T00:00:00+08:00
wyg


36
2009222
ddddd
22
2009-07-31T00:00:00+08:00
wyg


37
1234455
ddddddd
11111
2009-07-31T00:00:00+08:00
wyg


///
/// 读取Xml文件,获得所有节点的Value值
///
/// Xml文件名
/// 存放的路径
/// Xml根节点名称
///
public void ImportXmlFile(string fileName,string filePath,string rootName)
{
string loadPath = HttpContext.Current.Server.MapPath(filePath + fileName);
try
{
XmlDocument xmldoc = new XmlDocument();
xmldoc.Load(loadPath);
//获取根节点的所有子节点
XmlNodeList myNodeList = xmldoc.SelectSingleNode(rootName).ChildNodes;
//遍历的所有子节点
foreach (XmlNode myXmlNode in myNodeList)
{
XmlNodeList subNodeList = myXmlNode.ChildNodes;
UpdateLogs updateLog = new UpdateLogs();
foreach (XmlNode subXmlNode in subNodeList)
{
switch (subXmlNode.Name)
{
case "id": //节点的名称,加这个条件是因为这些节点也会被读出来
updateLog.ID = int.Parse(subXmlNode.InnerText.Trim());
break;
case "title":
updateLog.Title = subXmlNode.InnerText.Trim();
break;
case "content":
updateLog.Content = subXmlNode.InnerText.Trim();
break;
case "module":
updateLog.Module = subXmlNode.InnerText.Trim();
break;
case "updateTime":
updateLog.UpdateTime = DateTime.Parse(subXmlNode.InnerText.Trim());
break;
case "operator":
updateLog.Operator = subXmlNode.InnerText.Trim();
break;
default:
break;
}
}
if (isExstsById(updateLog.ID.ToString()))
{
UpdateLog(updateLog);
}
else
{
InsertLog(updateLog);
}
}
File.Delete(loadPath);
BindData();
ClientScript.RegisterStartupScript(typeof(string), "importLog", "alert('导入成功!');");
}
catch (Exception ex)
{
ExceptionManager.Handle(ex);
}
}

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux下的php文件放在哪个文件夹下才能访问
  • 请问如何才能将大量文件合并成一个文件并去除所有空行?
  • 请问:copy文件和删除文件怎样才能不用“确认”呢?
  • 我要下载*.txt文件,怎样才能出现下载对话框,而不是在IE里面直接打开*.txt文件
  • 请问xvfs是什么文件系统?怎样才能让linux认出?
  • qt生成的EXE文件需要它本身的DLL文件才能执行。请问怎么解决
  • 用什么软件才能打开后缀为.z的文件?
  • 我已在一個.java文件中寫了package radom ,在javac時我怎樣才能創建,並把.class文件放到radom中??
  • 刚装上linux,我怎样才能看到windows(FAT32)下的文件?
  • 我已在一個.java文件中寫了package radom ,在javac時我怎樣才能創建,並把.class文件放到radom中??(
  • 我不知道怎么才能用JBuilder写的窗口变成个可执行文件
  • Windows xp下如何才能访问安装在虚拟机上LINUX的文件目录信息
  • 不小心把home下的bin文件夹删除了,如何才能启动unix呀?急用
  • 高分请教:请问怎么才能得到最近所有有关文件操作(新建,删除等)的记录
  • linux 下怎么才能找到想要的文件?
  • mpeg2格式的数据流,封装成什么文件格式dvd影碟机才能播放
  • linux下的FTP登陆后进入到用户文件夹,怎么样配置才能让这个用户可以访问任意的文件夹
  • 在GTK的打开对话框中,怎样才能删除文件?
  • 用VIM做多行匹配,怎样才能将匹配结果输出到文件?
  • 怎样才能让applet访问本地文件呢?
  • 半路出家转行学编程如何才能成为大牛?
  • 修改了hosts.allow,怎么才能生效,是启动了哪个服务才能生效吗?
  • 请较:用window2000做网关,现在LINUX怎么设置才能才能通过它上网呢?
  • 在applet中怎么才能得到当前页面的接口,我的意思是说怎样才能改变比如说一个输入框中的内容
  • 如何才能再次进入linux?
  • 提示文字怎样才能按多行显示?
  • 如何才能在java(vj环境下)播放声音?
  • HTML教程 iis7站长之家
  • 为什么Component的组件要add后才能paint()?
  • 我怎么才能知道一个线程已经执行结束?
  • 请教各位高手一个简单的问题:在JAVA 中如何才能取得一些系统信息?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3