c# 對Xml的增刪改查

XMl文件

<?xml version="1.0" standalone="yes"?>
<dbGuest>
<User>
    <Name>Guset</Name>
    <City>上海</City>
    <Email>fdfd</Email>
</User>
<User>
    <Name>Gu</Name>
    <City>上海</City>
    <Email>fdfd</Email>
</User>
</dbGuest>

 

 

訪問的類

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Xml;
using System.Xml.XPath;
namespace DsAndXML.OpXMLFile
{
/// <summary>
/// Main 的摘要說明。
/// </summary>
public partial class Main : System.Web.UI.Page
{

   protected void Page_Load(object sender, System.EventArgs e)
   {
    // 在此處放置用戶代碼以初始化頁面
    if(!IsPostBack)
    Bind();

   }

        //綁定數據
   private void Bind()
   {
    DataSet ds = new DataSet();
    ds.ReadXml(Server.MapPath(".//db//dbGuest.xml"));
    dgShow.DataSource = ds.Tables[0].DefaultView;
    dgShow.DataBind();
    XmlDocument doc = new XmlDocument();
    doc.Load(Server.MapPath(".//db//dbGuest.xml"));
    XmlNodeList elemList = doc.GetElementsByTagName("Name");
    ddlName.Items.Clear();
    for(int i=0;i<elemList.Count;i++)
    ddlName.Items.Add(elemList[i].InnerXml);
   
   }

   #region Web Form Designer generated code
   override protected void OnInit(EventArgs e)
   {
    //
    // CODEGEN:該調用是 ASP.NET Web 窗體設計器所必需的。
    //
    InitializeComponent();
    base.OnInit(e);
   }
  
   /// <summary>
   /// 設計器支持所需的方法 - 不要使用代碼編輯器修改
   /// 此方法的內容。
   /// </summary>
   private void InitializeComponent()
   {   

   }
   #endregion

        //查詢一個數據
   protected void btnQuery_Click(object sender, System.EventArgs e)
   {
    XmlDocument doc = new XmlDocument();
    doc.Load(Server.MapPath(".//db//dbGuest.xml"));
      lbEmail.Text = doc.SelectSingleNode("//User[Name='"+ddlName.SelectedItem.Text+"']").ChildNodes.Item(2).InnerText;
        
   }

        //修改一個數據
   protected void btnChange_Click(object sender, System.EventArgs e)
   {
    XmlDocument xmlDoc = new XmlDocument();
    xmlDoc.Load(Server.MapPath(".//db//dbGuest.xml"));
            xmlDoc.SelectSingleNode("//User[Name='"+ddlName.SelectedItem.Text+"']").ChildNodes.Item(2).InnerText = tbNewMail.Text.ToString().Trim();//獲取dbGuest節點的所有子節點
    xmlDoc.Save(Server.MapPath(".//db//dbGuest.xml"));
    Bind();
   }

        //刪除一個數據
   protected void btnDelete_Click(object sender, System.EventArgs e)
   {
    XmlDocument xmlDoc = new XmlDocument();
    xmlDoc.Load(Server.MapPath(".//db//dbGuest.xml"));
            xmlDoc.SelectSingleNode("//User[Name='" + ddlName.SelectedItem.Text + "']").RemoveAll();
            xmlDoc.Save(Server.MapPath(".//db//dbGuest.xml"));
            Bind();
   }

        //添加一個數據
   protected void btnAdd_Click(object sender, System.EventArgs e)
   {
    XmlDocument xmlDoc = new XmlDocument();
    xmlDoc.Load(Server.MapPath(".//db//dbGuest.xml"));
    XmlNode root=xmlDoc.SelectSingleNode("dbGuest");//查找<dbGuest>
    XmlElement xe1=xmlDoc.CreateElement("User");//創建一個<User>節點
    XmlElement xesub1=xmlDoc.CreateElement("Name");
    xesub1.InnerText="Guset";//設置文本節點
    xe1.AppendChild(xesub1);//添加到<User>節點中
    XmlElement xesub2=xmlDoc.CreateElement("City");
    xesub2.InnerText="鄭州";
    xe1.AppendChild(xesub2);
    XmlElement xesub3=xmlDoc.CreateElement("Email");
    xesub3.InnerText = "[email protected]";
    xe1.AppendChild(xesub3);

    root.AppendChild(xe1);//添加到<dbGuest>節點中
    xmlDoc.Save(Server.MapPath(".//db//dbGuest.xml"));
    Bind();
   }
}
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章