步步为营VS 2008 + .NET 3.5(14) - XLINQ(LINQ to XML)之针对XML文件的添加、查询、更新和删除

简介:
[索引页]
[源码下载]


步步为营VS 2008 + .NET 3.5(14) - XLINQ(LINQ to XML)之针对XML文件的添加、查询、更新和删除


作者: webabcd


介绍
以某一XML文件为例,XLINQ(LINQ to XML)之针对XML文件的添加操作、查询操作、更新操作和删除操作


示例
Sample.xml
<? xml  version ="1.0"  encoding ="utf-8" ?> 
< root > 
     < person  name ="webabcd"  age ="27"  salary ="33"  /> 
</ root >
 
Sample.aspx
<%@ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="Sample.aspx.cs" 
        Inherits="LINQ_XLINQ_Sample" Title="针对XML文件的添加、查询、更新和删除" %> 

<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="Server"> 
</asp:Content> 
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server"> 
        <p> 
                姓名:<asp:TextBox ID="txtName" runat="server"></asp:TextBox> 
                   年龄:<asp:TextBox ID="txtAge" runat="server"></asp:TextBox> 
                   薪水:<asp:TextBox ID="txtSalary" runat="server"></asp:TextBox> 
                <asp:Button ID="btnAdd" runat="server" Text="添加" OnClick="btnAdd_Click" /> 
        </p> 
        <asp:GridView ID="gvPerson" runat="server" DataKeyNames="name" OnSelectedIndexChanged="gvPerson_SelectedIndexChanged" 
                OnRowDeleting="gvPerson_RowDeleting" OnRowCancelingEdit="gvPerson_RowCancelingEdit" 
                OnRowEditing="gvPerson_RowEditing" OnRowUpdating="gvPerson_RowUpdating"> 
                <Columns> 
                        <asp:CommandField ShowSelectButton="True" ShowEditButton="True" ShowDeleteButton="True"> 
                        </asp:CommandField> 
                </Columns> 
        </asp:GridView> 
        <br /> 
        <asp:DetailsView ID="dvPerson" runat="server" DataKeyNames="name"> 
        </asp:DetailsView> 
</asp:Content>
 

Sample.aspx.cs
using System; 
using System.Data; 
using System.Configuration; 
using System.Collections; 
using System.Linq; 
using System.Web; 
using System.Web.Security; 
using System.Web.UI; 
using System.Web.UI.WebControls; 
using System.Web.UI.WebControls.WebParts; 
using System.Web.UI.HtmlControls; 
using System.Xml.Linq; 
 
public partial  class LINQ_XLINQ_Sample : System.Web.UI.Page 

         protected  void Page_Load( object sender, EventArgs e) 
        { 
                 if (!Page.IsPostBack) 
                { 
                        BindPerson(); 
                } 
        } 
 
         private  void BindPerson() 
        { 
                 // 加载指定的xml文件 
                XDocument xml = XDocument.Load(Server.MapPath( "Sample.xml")); 
 
                 // 使用查询语法获取Person集合 
                var persons = from p  in xml.Root.Elements( "person"
                                            select  new 
                                            { 
                                                    name = p.Attribute( "name").Value, 
                                                    age = p.Attribute( "age").Value, 
                                                    salary = p.Attribute( "salary").Value 
                                            }; 
 
                gvPerson.DataSource = persons; 
                gvPerson.DataBind(); 
        } 
 
         protected  void btnAdd_Click( object sender, EventArgs e) 
        { 
                 // 加载指定的xml文件 
                XDocument xml = XDocument.Load(Server.MapPath( "Sample.xml")); 
 
                 // 创建需要新增的XElement对象 
                XElement person =  new XElement( 
                         "person"
                         new XAttribute( "name", txtName.Text), 
                         new XAttribute( "age", txtAge.Text), 
                         new XAttribute( "salary", txtSalary.Text)); 
 
                 // 添加需要新增的XElement对象 
                xml.Root.Add(person); 
                 
                 // 保存xml 
                xml.Save(Server.MapPath( "Sample.xml")); 
 
                gvPerson.EditIndex = -1; 
                BindPerson(); 
        } 
 
         protected  void gvPerson_SelectedIndexChanged( object sender, EventArgs e) 
        { 
                 // 加载指定的xml文件 
                XDocument xml = XDocument.Load(Server.MapPath( "Sample.xml")); 
 
                 // 使用查询语法获取指定的Person集合 
                var persons = from p  in xml.Root.Elements( "person"
                                            where p.Attribute( "name").Value == gvPerson.SelectedValue.ToString() 
                                            select  new 
                                            { 
                                                    name = p.Attribute( "name").Value, 
                                                    age = p.Attribute( "age").Value, 
                                                    salary = p.Attribute( "salary").Value 
                                            }; 
 
                dvPerson.DataSource = persons; 
                dvPerson.DataBind(); 
        } 
 
         protected  void gvPerson_RowDeleting( object sender, GridViewDeleteEventArgs e) 
        { 
                 // 加载指定的xml文件 
                XDocument xml = XDocument.Load(Server.MapPath( "Sample.xml")); 
 
                 // 使用查询语法获取指定的Person集合 
                var persons = from p  in xml.Root.Elements( "person"
                                            where p.Attribute( "name").Value == gvPerson.DataKeys[e.RowIndex].Value.ToString() 
                                            select p; 
 
                 // 删除指定的XElement对象 
                persons.Remove(); 
 
                 // 保存xml 
                xml.Save(Server.MapPath( "Sample.xml")); 
 
                gvPerson.EditIndex = -1; 
                BindPerson(); 
        } 
 
         protected  void gvPerson_RowUpdating( object sender, GridViewUpdateEventArgs e) 
        { 
                 // 加载指定的xml文件 
                XDocument xml = XDocument.Load(Server.MapPath( "Sample.xml")); 
 
                 // 使用查询语法获取指定的Person集合 
                var persons = from p  in xml.Root.Elements( "person"
                                            where p.Attribute( "name").Value == gvPerson.DataKeys[e.RowIndex].Value.ToString() 
                                            select p; 
 
                 // 更新指定的XElement对象 
                 foreach (XElement xe  in persons) 
                { 
                        xe.SetAttributeValue( "age", ((TextBox)gvPerson.Rows[e.RowIndex].Cells[2].Controls[0]).Text); 
                        xe.SetAttributeValue( "salary", ((TextBox)gvPerson.Rows[e.RowIndex].Cells[3].Controls[0]).Text); 
                } 
 
                 // 保存xml 
                xml.Save(Server.MapPath( "Sample.xml")); 
 
                gvPerson.EditIndex = -1; 
                BindPerson(); 
        } 
 
         protected  void gvPerson_RowEditing( object sender, GridViewEditEventArgs e) 
        { 
                gvPerson.EditIndex = e.NewEditIndex; 
                BindPerson(); 
        } 
 
         protected  void gvPerson_RowCancelingEdit( object sender, GridViewCancelEditEventArgs e) 
        { 
                gvPerson.EditIndex = -1; 
                BindPerson(); 
        } 
}
 
 




     本文转自webabcd 51CTO博客,原文链接: http://blog.51cto.com/webabcd/345020 ,如需转载请自行联系原作者

相关文章
|
4月前
|
XML 前端开发 Java
讲解SSM的xml文件
本文详细介绍了SSM框架中的xml配置文件,包括springMVC.xml和applicationContext.xml,涉及组件扫描、数据源配置、事务管理、MyBatis集成以及Spring MVC的视图解析器配置。
113 1
|
2月前
|
Linux C# Windows
.NET使用MiniWord高效生成Word文件
.NET使用MiniWord高效生成Word文件
56 12
|
3月前
|
XML Android开发 数据格式
Eclipse 创建 XML 文件
Eclipse 创建 XML 文件
51 2
|
3月前
|
Java Maven
maven项目的pom.xml文件常用标签使用介绍
第四届人文,智慧教育与服务管理国际学术会议(HWESM 2025) 2025 4th International Conference on Humanities, Wisdom Education and Service Management
305 8
|
3月前
Visual Studio 快速分析 .NET Dump 文件
【11月更文挑战第10天】.NET Dump 文件是在 .NET 应用程序崩溃或出现问题时生成的,记录了应用程序的状态,包括内存对象、线程栈和模块信息。通过分析这些文件,开发人员可以定位和解决内存泄漏、死锁等问题。在 Visual Studio 中,可以通过调试工具、内存分析工具和符号加载等功能来详细分析 Dump 文件。此外,还可以使用第三方工具如 WinDbg 进行更深入的分析。
137 1
|
3月前
|
XML 开发框架 .NET
.NET 9 中 LINQ 新增功能实操
.NET 9 中 LINQ 新增功能实操
|
4月前
|
XML JavaScript Java
java与XML文件的读写
java与XML文件的读写
51 3
|
4月前
|
C# Windows
一款基于.NET开发的简易高效的文件转换器
一款基于.NET开发的简易高效的文件转换器
|
4月前
|
开发框架 .NET 开发工具
.NET 9 中 LINQ 新增的功能
.NET 9 中 LINQ 新增的功能
|
4月前
|
XML 存储 缓存
C#使用XML文件的详解及示例
C#使用XML文件的详解及示例
198 0

热门文章

最新文章

相关课程

更多