扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
在本页阅读全文(共19页)
using System.Xml; //处理XML必须加的Namespace,还需在References中加System.XML.Dll using System.IO; //读XML文件必须加的Namespace |
protected void Page_Load(object sender, EventArgs e){ string datafile="guest.xml" ; //假设XML文件名为guest.xml StreamReader tyj=new StreamReader(Server.MapPath(datafile)); XmlDataDocument datadoc = new XmlDataDocument(); //创建该对象为了读取XML datadoc.DataSet.ReadXml(tyj); //读取guest.xml文件内容 DataGrid1.DataSource = datadoc.DataSet.Tables[0].DefaultView; //设置DataGrid数据源 DataGrid1.DataBind(); //绑定 datadoc=null ; //释放资源 tyj.Close();} //释放StreamReader类,这非常重要,否则下次打开会显示文件已经被使用 |
protected void OnSelectName(object sender,EventArgs e) { Session["select_name"]=(string)DataGrid1.SelectedItem.Cells[1].Text.ToString(); //把选定的 DataGrid某行中的一个单元中的值(Name)存入一个会话变量中,以便下一页用 Response.Redirect("xml_manage.aspx");} //转到有增加删除功能的管理页 |
string datafile = "guest.xml" ;XmlDocument xmldocument = new XmlDocument() ; xmldocument.Load(Server.MapPath(datafile)) ; //把guest.xml读到xmldocument中 DocumentNavigator navigator = new DocumentNavigator(xmldocument) ; //最重要的类 navigator.MoveToDocumentElement() ; navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Element, "Guest","","") ;//插入节点Guest navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Element, "Name","","") ; navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Text,"Name","","") ; navigator.Value=Name.Text ; //为该节点赋值 navigator.MoveToParent() ; //返回父节点 Guest …… //使用同类语句,在元素Name下插入另一些元素如Country、E-mail地址和留言等 xmldocument.Save(Server.MapPath(datafile)); //最后保存这个XML文档 navigator=null ; xmldocument=null ; //释放XML文档,这样其他程序可以用它 |
string datafile = "guest.xml" ; XmlDocument xmldocument = new XmlDocument() ; xmldocument.Load(Server.MapPath(datafile)) ; //把guest.xml读到xmldocument中 DocumentNavigator navigator = new DocumentNavigator(xmldocument) ; navigator.MoveToDocumentElement() ; navigator.Select("/Guests/Guest[Name='"+Session["select_name"]+"']"); //参数是Xpath navigator.RemoveSelected(); //执行删除 xmldocument.Save(Server.MapPath(datafile)); //最后保存这个XML文档 navigator=null; //释放类 xmldocument=null ; //释放XML文档,这样其他程序可以用它 |
如需将XML文件中所有信息清除,使用“navigator.RemoveChildren();”语句即可实现。
综上可知,C#编写XML应用程序不但快捷而且方便,在编写ASP.NET数据库应用程序时,用XML文件替代一些小的Table,能减少许多数据库存取连接,也能让其他网络程序更易使用这些数据。
目前XML的主要瓶颈在于文件系统的读出或写入,故应使用更多内存和缓存方式,如果信息量不是巨大无比且修改量也较小,而浏览量巨大的话,使用XML方法将是很好的选择;相反,如数据量巨大,应考虑使用支持XML的数据库,无论你使用ADO+连接其他数据库,还是使用SQL server,C#中都有直接的类函数可让这些数据库中的信息直接和XML交互访问。
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者