中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

xml的增刪改查用法

發布時間:2021-08-16 10:41:17 來源:億速云 閱讀:98 作者:chen 欄目:編程語言

這篇文章主要講解了“xml的增刪改查用法”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“xml的增刪改查用法”吧!

在項目開發中,我們經常會對某張表進行增刪改查。我們根據條件刷選表中的數據放到gridview中以列表形式展現,同時給gridview添加各種樣式,比如一般必用的鼠標經過,鼠標離開顏色變化,行選中等顏色加深,同時給列表數據項賦值,單擊保存按鈕可以修改一條已存在的數據或者添加一條新的數據,單擊按鈕添加,列表數據項清空,單擊刪除,可以刪除一條數據。

由于為了方便大家把代碼復制一下,在脫離數據的情況下,就可以看到效果,所以,我把數據存放在xml,所以讀取數據不是通過數據庫,是通過跟xml文件交互實現的。所以做了下面對xml增刪改查頁面。

效果圖:

xml的增刪改查用法

首先列出XML文件,方便代碼參照

內容.xml

<?xml version="1.0" encoding="utf-8"?>
<config>
  <Header ID="ID" class="class" class_name="class_name" year="year" school="school" count="count">
  </Header>
  <rows ID="01" class="一五班" class_name="實驗班" year="2013" school="三峽高級中學" count="30">
  </rows>
  <rows ID="02" class="一六班" class_name="奧數班" year="2013" school="三峽高級中學" count="45">
  </rows>
  <rows ID="03" class="一七班" class_name="陽光班" year="2013" school="三峽高級中學" count="60">
  </rows>
  <rows ID="04" class="一八班" class_name="美術班" year="2013" school="三峽高級中學" count="75">
  </rows>
</config>

一,核心代碼:

1) 修改xml

   /// <summary>
        /// 修改XML
        /// </summary>
        /// <param name="xmlName">XML文件名</param>
        /// <param name="ht">存放信息哈希表</param>
        /// <param name="ID">主鍵值</param>
        public void saveXML(string xmlName,Hashtable ht,string ID)
        {
            string fileName=HttpContext.Current.Request.PhysicalApplicationPath+"\\Xml\\"+xmlName+".xml";//xml的物理路徑
            XmlDocument xmlDoc=new XmlDocument ();
            xmlDoc.Load(fileName);
            XmlNode node = xmlDoc.SelectSingleNode("config/rows[@ID=" + ID + "]");
            foreach (XmlNode node1 in node.Attributes)
            {
                if (ht.ContainsKey(node1.Name)&&node1.Name!="ID")
                {
                    node1.Value = ht[node1.Name].ToString();
                }
            }
            xmlDoc.Save(fileName);
        }

ht:

  Hashtable ht = new Hashtable();
        ht.Add("ID", this.txt_ID.Value);
        ht.Add("class", this.txt_class.Value);
        ht.Add("class_name", this.txt_class_name.Value);
        ht.Add("year", this.txt_year.Value);
        ht.Add("school", this.txt_school.Value);
        ht.Add("count", this.txt_count.Value);

2)插入xml

    /// <summary>
        /// 插入xml
        /// </summary>
        /// <param name="xmlName">XML文件名</param>
        /// <param name="ht">存放信息哈希表</param>
        /// <returns></returns>
        public string insertXml(string xmlName, Hashtable ht)
        {
            string fileName = HttpContext.Current.Request.PhysicalApplicationPath + "\\Xml\\" + xmlName + ".xml";//xml的物理路徑
            XmlDocument xmlDoc = new XmlDocument();
            xmlDoc.Load(fileName);
            XmlNode node = xmlDoc.SelectSingleNode("//rows[last()]");//最后一個行節點
            XmlNode MaxNode = xmlDoc.SelectSingleNode("//rows/@ID[not(.<//rows/@ID)]");//獲取主鍵最大值
            if (int.Parse(ht[MaxNode.Name].ToString()) <= int.Parse(MaxNode.Value))//如果小于主鍵最大值,那么返回-
            {
                return "-1";
            }
            XmlElement xe = xmlDoc.CreateElement("rows");
            xe.InnerText = "";
            foreach (XmlNode node1 in node.Attributes)
            {
                if (ht.ContainsKey(node1.Name))
                {
                    xe.SetAttribute(node1.Name, ht[node1.Name].ToString());
                }
                else
                {
                    xe.SetAttribute(node1.Name,"");
                }
            }
            node.ParentNode.AppendChild(xe);
            xmlDoc.Save(fileName);
            return "1";
        }

3)  刪除xml

   /// <summary>
        /// 刪除xml節點
        /// </summary>
        /// <param name="xmlName">XML文件名</param>
        /// <param name="ID">主鍵值</param>
        /// <param name="primaryKey">主鍵名</param>
        /// <returns></returns>
        public string deleteXml(string xmlName,string ID,string primaryKey)
        {
            string rtn = string.Empty;
            string fileName = HttpContext.Current.Request.PhysicalApplicationPath + "\\Xml\\" + xmlName + ".xml";//xml的物理路徑
            XmlDocument xmlDoc = new XmlDocument();
            xmlDoc.Load(fileName);
            XmlNode node = xmlDoc.SelectSingleNode("//rows[@"+primaryKey+"='"+ID+"']");//最后一個行節點
            if (node ==null)
            {
                rtn = "-1";
            }
            else
            {
                node.ParentNode.RemoveChild(node);
                rtn = "1";
            }
            xmlDoc.Save(fileName);
            return rtn;
        }

感謝各位的閱讀,以上就是“xml的增刪改查用法”的內容了,經過本文的學習后,相信大家對xml的增刪改查用法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

xml
AI

炉霍县| 金华市| 晋宁县| 临城县| 绵阳市| 镇原县| 焦作市| 江西省| 平利县| 丰城市| 临沧市| 铁岭县| 凤凰县| 太仆寺旗| 石泉县| 繁昌县| 武功县| 河曲县| 正阳县| 阜阳市| 逊克县| 勃利县| 云霄县| 望江县| 中江县| 临沂市| 枣庄市| 吴江市| 腾冲县| 汝城县| 慈溪市| 梅河口市| 迁安市| 麟游县| 定陶县| 青浦区| 东城区| 麻城市| 通道| 长沙市| 桃园县|