[問題] 寫入XML的問題
前輩好,小弟有一個需求需要從資料庫的部分欄位建置成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
推
11/30 13:33, , 1F
11/30 13:33, 1F
→
11/30 15:16, , 2F
11/30 15:16, 2F
推
12/02 16:33, , 3F
12/02 16:33, 3F
→
12/02 16:33, , 4F
12/02 16:33, 4F
討論串 (同標題文章)