步步为营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 ,如需转载请自行联系原作者

相关文章
|
3月前
|
XML 前端开发 Java
讲解SSM的xml文件
本文详细介绍了SSM框架中的xml配置文件,包括springMVC.xml和applicationContext.xml,涉及组件扫描、数据源配置、事务管理、MyBatis集成以及Spring MVC的视图解析器配置。
91 1
|
5月前
|
XML Java 数据格式
Spring5入门到实战------7、IOC容器-Bean管理XML方式(外部属性文件)
这篇文章是Spring5框架的实战教程,主要介绍了如何在Spring的IOC容器中通过XML配置方式使用外部属性文件来管理Bean,特别是数据库连接池的配置。文章详细讲解了创建属性文件、引入属性文件到Spring配置、以及如何使用属性占位符来引用属性文件中的值。
Spring5入门到实战------7、IOC容器-Bean管理XML方式(外部属性文件)
|
2月前
|
XML Android开发 数据格式
Eclipse 创建 XML 文件
Eclipse 创建 XML 文件
33 2
|
2月前
|
Java Maven
maven项目的pom.xml文件常用标签使用介绍
第四届人文,智慧教育与服务管理国际学术会议(HWESM 2025) 2025 4th International Conference on Humanities, Wisdom Education and Service Management
210 8
|
2月前
|
XML 开发框架 .NET
.NET 9 中 LINQ 新增功能实操
.NET 9 中 LINQ 新增功能实操
|
3月前
|
XML JavaScript Java
java与XML文件的读写
java与XML文件的读写
34 3
|
3月前
|
开发框架 .NET 开发工具
.NET 9 中 LINQ 新增的功能
.NET 9 中 LINQ 新增的功能
|
3月前
|
XML 存储 缓存
C#使用XML文件的详解及示例
C#使用XML文件的详解及示例
142 0
|
3月前
|
XML 存储 Web App开发
查看 XML 文件
查看 XML 文件
|
4月前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
77 1