作者Futurend (未來)
看板C_Sharp
標題[問題] 寫入XML的問題
時間Tue Nov 30 12:41:21 2010
前輩好,小弟有一個需求需要從資料庫的部分欄位建置成XML文件
雖然說DataSet可以自動輸出成XML
但是想試著嘗試自己實作出來這樣的功能
上網找過之後,寫法如下:
XmlDocument doc = new XmlDocument();
XmlElement elmDoc = doc.CreateElement("ItemList");
foreach (DataRow dr in ds.Tables[0].Rows)
{
XmlElement elm = doc.CreateElement("Item");
elm.SetAttribute("Id", Util.GetSapValue(dr, "RSPOS"));
XmlElement elmPart = doc.CreateElement("PartNo");
elmPart.InnerText = dr["PartNo"].ToString();
elm.AppendChild(elmPart);
XmlElement elmStandard = doc.CreateElement("Standard");
elmStandard.InnerText = dr["Standard"].ToString();
elm.AppendChild(elmStandard);
XmlElement elmDescription = doc.CreateElement("Description");
elmDescription.InnerText = dr["Description"].ToString();
elm.AppendChild(elmDescription);
XmlElement elmBatch = doc.CreateElement("Batch");
elmBatch.InnerText = dr["Batch"].ToString();
elm.AppendChild(elmBatch);
XmlElement elmApplyAmount = doc.CreateElement("ApplyAmount");
elmApplyAmount.InnerText = dr["ApplyAmount"].ToString();
elm.AppendChild(elmApplyAmount);
XmlElement elmStaff = doc.CreateElement("Staff");
elmStaff.InnerText = dr["Staff"].ToString();
elm.AppendChild(elmStaff);
elmDoc.AppendChild(elm);
}
doc.AppendChild(elmDoc);
雖然說這樣可以達到我要的效果
但還是想請教前輩
這樣的寫法,有沒有什麼需要改善的地方、會不會出現什麼問題
或著有沒有更簡潔的寫法
再實作中我也產生了一些疑問
像是,
1 ) 既然都可以用XmlElement完成,那XmlNode什麼時候使用比較適當
2 ) 假如我根節點只有一個,那有沒有辦法省略掉那個根節點,在程式碼編寫上
3 ) 為什麼Element都需要從doc去Create出來,是因為命名空間的關係嗎
還請前輩不吝指教,尤其是該如何去改良這樣的程式碼
來完成建構一個xml文件的動作
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 118.169.184.174
推 Deadshot465:LINQ to XML? 11/30 13:33
→ Futurend:因為系統限制無法使用LINQ = =.. 不過這邊主要只有寫入 11/30 15:16
推 petrushka:簡潔一點的寫法,就是改用程式讀Column Name, 而不是寫死 12/02 16:33
→ petrushka:在程式碼內. 這樣也會比較有彈性一點 12/02 16:33