看板 C_Sharp 關於我們 聯絡資訊
前輩好,小弟有一個需求需要從資料庫的部分欄位建置成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