xml的增刪改查用法-創(chuàng)新互聯(lián)

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

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括原陽網(wǎng)站建設(shè)、原陽網(wǎng)站制作、原陽網(wǎng)頁制作以及原陽網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,原陽網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到原陽省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

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

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

效果圖:

xml的增刪改查用法

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

內(nèi)容.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="實(shí)驗(yàn)班" year="2013" school="三峽高級(jí)中學(xué)" count="30">
  </rows>
  <rows ID="02" class="一六班" class_name="奧數(shù)班" year="2013" school="三峽高級(jí)中學(xué)" count="45">
  </rows>
  <rows ID="03" class="一七班" class_name="陽光班" year="2013" school="三峽高級(jí)中學(xué)" count="60">
  </rows>
  <rows ID="04" class="一八班" class_name="美術(shù)班" year="2013" school="三峽高級(jí)中學(xué)" 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()]");//最后一個(gè)行節(jié)點(diǎn)
            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節(jié)點(diǎn)
        /// </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+"']");//最后一個(gè)行節(jié)點(diǎn)
            if (node ==null)
            {
                rtn = "-1";
            }
            else
            {
                node.ParentNode.RemoveChild(node);
                rtn = "1";
            }
            xmlDoc.Save(fileName);
            return rtn;
        }

感謝各位的閱讀,以上就是“xml的增刪改查用法”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)xml的增刪改查用法這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

新聞名稱:xml的增刪改查用法-創(chuàng)新互聯(lián)
本文地址:http://muchs.cn/article30/ceesso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、定制網(wǎng)站、營銷型網(wǎng)站建設(shè)小程序開發(fā)、全網(wǎng)營銷推廣、ChatGPT

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管