Linq to XML同样是对原C#访问XML文件的方法的封装,简化了用xpath进行xml的查询以及增加,修改,删除xml元素的操作。
C#访问XML文件的常用类:XmlDocument,XmlElement,XmlAttribute,XmlNode,XmlText等;

Linq to XML 中的常用类 :XDocument,XElement,XAttribute。 废话不多说了,直接上代码: xml文件数据格式如下

public class DataBaseInfo

{

public string ID { get; set; }

public string Company { get; set; }

public string Server { get; set; }

public string DataBase { get; set; }

public string UserName { get; set; }

public string Password { get; set; }

private static XDocument doc = new XDocument();

public static string filePath = ".\\DataBaseInfo.xml";

public DataBaseInfo() {

doc = XDocument.Load(filePath);

}

public DataBaseInfo(string filepath):this()

{

filePath = filepath;

}

/// <summary>

/// 增

/// </summary>

/// <returns></returns>

public  bool Add()

{

XElement db = new XElement("DataBase",

new XAttribute("id", ID),

new XElement("company", new XAttribute("value",Company)),

new XElement("server", new XAttribute("value",Server)),

new XElement("database", new XAttribute("value",DataBase)),

new XElement("username", new XAttribute("value",UserName)),

new XElement("password", new XAttribute("value", Password))

);

try

{

//用XElement的Add方法

//XElement doc = XElement.Load(filePath);

//doc.Add(db);

//用XDocument的Add方法

doc.Element("DataBases").Add(db);

doc.Save(filePath);

return true;

}

catch

{

return false;

}

}

/// <summary>

/// 删

/// </summary>

/// <param name="id"></param>

/// <returns></returns>

public static bool Remove(string id)

{

XElement xe = (from db in doc.Element("DataBases").Elements("DataBase") where db.Attribute("id").Value == id select db).Single() as XElement;

try

{

xe.Remove();

doc.Save(filePath);

return true;

}

catch

{

return false;

}

}

/// <summary>

/// 改

/// </summary>

/// <returns></returns>

public bool Modify()

{

XElement xe = (from db in doc.Element("DataBases").Elements("DataBase") where db.Attribute("id").Value.ToString() == ID select db).Single();

try

{

xe.Element("company").Attribute("value").Value = Company;

xe.Element("server").Attribute("value").Value = Server;

xe.Element("database").Attribute("value").Value = DataBase;

xe.Element("username").Attribute("value").Value = UserName;

xe.Element("password").Attribute("value").Value = Password;

doc.Save(filePath);

return true;

}

catch

{

return false;

}

}

/// <summary>

/// 查

/// </summary>

/// <returns></returns>

public List<DataBaseInfo> GetAll()

{

List<DataBaseInfo> dbs = (from db in doc.Element("DataBases").Elements("DataBase")

select new DataBaseInfo

{

ID = db.Attribute("id").Value.ToString(),

Company = db.Element("company").Attribute("value").Value.ToString(),

Server = db.Element("server").Attribute("value").Value.ToString(),

DataBase = db.Element("database").Attribute("value").Value.ToString(),

UserName = db.Element("username").Attribute("value").Value.ToString(),

Password = db.Element("password").Attribute("value").Value.ToString()

}).ToList();

return dbs;

}

怎么样,如何对之前DOM方式访问XML熟悉的话, 是不是发现简单了不少呢?

Linq to XML 增删改查的更多相关文章

  1. [原创]Linq to xml增删改查Linq 入门篇:分分钟带你遨游Linq to xml的世界

    本文原始作者博客 http://www.cnblogs.com/toutou Linq 入门篇(一):分分钟带你遨游linq to xml的世界 本文原创来自博客园 请叫我头头哥的博客, 请尊重版权, ...

  2. 使用python操作XML增删改查

    使用python操作XML增删改查 什么是XML? XML 指可扩展标记语言(EXtensible Markup Language) XML 是一种标记语言,很类似 HTML XML 的设计宗旨是传输 ...

  3. net对XML增删改查

    Pass:看公司代码,配置下拉框的功能,和下拉框的数字转文字.配置xml里面有下拉的value,name,这样界面直接显示数字,然后转译成中文 1.xml文件格式 <?xml version=& ...

  4. c# XML增删改查

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  5. linq的简单增删改查

    Linq高集成化的数据访问类,它会自动映射数据库结构,将表名完整映射成为类名,将列名完整映射成字段名数据库数据访问,能大大减少代码量.(反正最后结果就是不用写ado.Net那一套增删改查,有一套封装好 ...

  6. .net xml 增删改查基础复习及干货分享

    今天做做项目时,有一个需求需要用到一些固定的文本数据,觉得将这些需要存储的信息直接写在代码里很不友好,放在数据库中存储又觉得不够方便,自然就想到了使用xml来进行操作,我平常在项目中其实用到xml的机 ...

  7. Linq to sql 增删改查(转帖)

    http://blog.csdn.net/pan_junbiao/article/details/7015633   (LINQ To SQL 语法及实例大全) 代码 Code highlightin ...

  8. Linq To Xml操作XML增删改查

    对XML文件的操作在平时项目中经常要运用到,比如用于存放一些配置相关的内容:本文将简单运用Linq TO Xml对XML进行操作,主要讲解对XML的创建.加载.增加.查询.修改以及删除:重点在于类XD ...

  9. 4.Linq To Xml操作XML增删改查

    转自https://www.cnblogs.com/wujy/p/3366812.html 对XML文件的操作在平时项目中经常要运用到,比如用于存放一些配置相关的内容:本文将简单运用Linq TO X ...

随机推荐

  1. bzoj 3262 陌上花开 - CDQ分治 - 树状数组

    Description 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当 ...

  2. WebSocket、Socket

    https://www.cnblogs.com/jingmoxukong/p/7755643.html#undefined WebSocket 详解教程 WebSocket介绍,与Socket的区别 ...

  3. python操作串口

    import serial test = serial.Serial("COM1",115200)#这里就已经打开了串口 print(test.portstr) test.writ ...

  4. Python3 tkinter基础 Label imag显示图片

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  5. linux内核中的IPIs是什么?

    答: 处理器间中断(Interprocessor Interrupts)

  6. Eclipse和Tomcat使用过程的一些配置、错误等的总结记录

    背景:公司项目使用jdk1.6.tomcat7.SVN,本文总结使用到现在的一些配置和问题. 1.Eclipse项目几点配置:(1)Windows -> Preferences -> Ja ...

  7. 【团队】EasyKing的实现_1

    完成部分 三个功能类 英雄. 子弹. 瓦片地图. 一个设置类 地图 实现功能 瓦片地图 英雄移动 攻击 受到攻击 TODO 子弹攻击范围 地图.建筑物和英雄的碰撞箱 音效 英雄技能 建筑 双人联机 物 ...

  8. AtomicReference实现单例模式

    CAS是项乐观锁技术,当多个线程尝试使用CAS同时更新同一个变量时,只有其中一个线程能更新变量的值,而其它线程都失败,失败的线程并不会被挂起,而是被告知这次竞争中失败,并可以再次尝试. 乐观锁的一种实 ...

  9. 1、My Scripts

    1.写一个包含命令.变量和流程控制的语句来清除/var/log的messages日志文件的shell脚本.(P26)(11-21) 2.利用$0和(dirname.basename)取出当前路径的目录 ...

  10. el-cascader 级联选择器使用时遇到的一些问题

    Element UI Cascader官网文档 <el-form-item label="章节" style="margin-right: 64px"&g ...