[問題] 寫入XML的問題

看板C_Sharp作者 (未來)時間15年前 (2010/11/30 12:41), 編輯推噓2(202)
留言4則, 3人參與, 最新討論串1/2 (看更多)
前輩好,小弟有一個需求需要從資料庫的部分欄位建置成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
LINQ to XML?
11/30 13:33, 1F

11/30 15:16, , 2F
因為系統限制無法使用LINQ = =.. 不過這邊主要只有寫入
11/30 15:16, 2F

12/02 16:33, , 3F
簡潔一點的寫法,就是改用程式讀Column Name, 而不是寫死
12/02 16:33, 3F

12/02 16:33, , 4F
在程式碼內. 這樣也會比較有彈性一點
12/02 16:33, 4F
文章代碼(AID): #1Cz81pHk (C_Sharp)
文章代碼(AID): #1Cz81pHk (C_Sharp)