C#怎樣才能將XML文件導(dǎo)入SQL Server
問:怎樣才能將XML文件導(dǎo)入SQL Server 2000?
答:將XML文件導(dǎo)入SQL Server有若干種方法,這里提供其中的3種:
大容量裝載COM接口。如果需要將文檔的實(shí)體和屬性析取到關(guān)系表中,最快的方法就是使用SQL Server 2000 Extensible Markup Language 3.0 Service Pack 1(SQLXML 3.0 SP1)提供的大容量裝載COM接口。大容量狀態(tài)COM接口包含在SQLXML 3.0 SP1的免費(fèi)下載中。
textcopy.exe命令行實(shí)用工具。如果不希望將文檔的實(shí)體和屬性析取到關(guān)系表中,您可以使用textcopy.exe命令行實(shí)用工具。Textcopy.exe是將文本和image數(shù)據(jù)類型從單一服務(wù)器行或列移入或移出的優(yōu)秀工具。
數(shù)據(jù)轉(zhuǎn)換服務(wù)(DTS)。如果XML文檔很簡(jiǎn)單,您可以使用DTS將信息逐行析取到表中。這一方法要求您將XML文件定義為輸入數(shù)據(jù)源,將數(shù)據(jù)庫(kù)表定義為輸出數(shù)據(jù)源,并編寫ActiveX腳本剖析"<"和">"方式的字符輸入,以析取實(shí)體、屬性及其值。
要導(dǎo)入的Xml文件:
<?xml version="1.0" encoding="gb2312"?>
<Tbl_UpdateLogs>
<Table>
<id>32</id>
<title>新增執(zhí)法機(jī)構(gòu)頁(yè)面</title>
<content>qqqqqq</content>
<module>組織機(jī)構(gòu)</module>
<updateTime>2009-07-31T00:00:00+08:00</updateTime>
<operator>王永剛</operator>
</Table>
<Table>
<id>33</id>
<title>執(zhí)法人員資格頁(yè)面</title>
<content>大幅度放到大幅度放到</content>
<module>組織機(jī)構(gòu)</module>
<updateTime>2009-07-29T00:00:00+08:00</updateTime>
<operator>王永剛</operator>
</Table>
<Table>
<id>34</id>
<title>111111</title>
<content>dfdwdd</content>
<module>qwqwq</module>
<updateTime>2009-07-29T00:00:00+08:00</updateTime>
<operator>wyg</operator>
</Table>
<Table>
<id>35</id>
<title>qq</title>
<content>fjdldldsss</content>
<module>qqqqqqq</module>
<updateTime>2009-07-30T00:00:00+08:00</updateTime>
<operator>wyg</operator>
</Table>
<Table>
<id>36</id>
<title>2009222</title>
<content>ddddd</content>
<module>22</module>
<updateTime>2009-07-31T00:00:00+08:00</updateTime>
<operator>wyg</operator>
</Table>
<Table>
<id>37</id>
<title>1234455</title>
<content>ddddddd</content>
<module>11111</module>
<updateTime>2009-07-31T00:00:00+08:00</updateTime>
<operator>wyg</operator>
</Table>
</Tbl_UpdateLogs>
/// <summary>
/// 讀取Xml文件,獲得所有節(jié)點(diǎn)的Value值
/// </summary>
/// <param name="fileName">Xml文件名</param>
/// <param name="filePath">存放的路徑</param>
/// <param name="rootName">Xml根節(jié)點(diǎn)名稱</param>
/// <returns></returns>
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);
//獲取根節(jié)點(diǎn)<rootName>的所有子節(jié)點(diǎn)
XmlNodeList myNodeList = xmldoc.SelectSingleNode(rootName).ChildNodes;
//遍歷<根節(jié)點(diǎn)>的所有子節(jié)點(diǎn)
foreach (XmlNode myXmlNode in myNodeList)
{
XmlNodeList subNodeList = myXmlNode.ChildNodes;
UpdateLogs updateLog = new UpdateLogs();
foreach (XmlNode subXmlNode in subNodeList)
{
switch (subXmlNode.Name)
{
case "id": //節(jié)點(diǎn)的名稱,加這個(gè)條件是因?yàn)?lt;!---->這些節(jié)點(diǎn)也會(huì)被讀出來
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", "<script>alert('導(dǎo)入成功!');</script>");
}
catch (Exception ex)
{
ExceptionManager.Handle(ex);
}
}
相關(guān)文章
使用數(shù)字簽名實(shí)現(xiàn)數(shù)據(jù)庫(kù)記錄防篡改(Java實(shí)現(xiàn))
本文主要介紹了Java中使用數(shù)字簽名實(shí)現(xiàn)數(shù)據(jù)庫(kù)記錄防篡改的方法與步驟。具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01用幾行C#代碼實(shí)現(xiàn)定時(shí)關(guān)機(jī)/重啟(超詳細(xì)!建議新手練習(xí))
有很多的軟件都實(shí)現(xiàn)了自動(dòng)關(guān)機(jī)這樣的功能,下面這篇文章主要給大家介紹了關(guān)于利用幾行C#代碼實(shí)現(xiàn)定時(shí)關(guān)機(jī)/重啟的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-12-12C#獲取局域網(wǎng)MAC地址的簡(jiǎn)單實(shí)例
這篇文章主要介紹了C#獲取局域網(wǎng)MAC地址的簡(jiǎn)單實(shí)例,有需要的朋友可以參考一下2013-11-11Unity實(shí)現(xiàn)截屏以及根據(jù)相機(jī)畫面截圖
這篇文章主要為大家詳細(xì)介紹了Unity實(shí)現(xiàn)截屏以及根據(jù)相機(jī)畫面截圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04淺談static a[n*m]={0};中static的作用
下面小編就為大家?guī)硪黄獪\談static a[n*m]={0};中static的作用。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03C#實(shí)現(xiàn)微信公眾號(hào)群發(fā)消息(解決一天只能發(fā)一次的限制)實(shí)例分享
經(jīng)過幾天研究網(wǎng)上的代碼和謝燦大神的幫忙,今天終于用C#實(shí)現(xiàn)了微信公眾號(hào)群發(fā)消息,現(xiàn)在分享一下2013-09-09