C#之LINQ与XML

LINQ

1. LINQ is a bridge over  object-oriented languages and relational database.

2. 注意查询格式与SQL的不同:

    Customer是一个类,customers是一个list容器,里面的数据是Customer型的。

IEnumerable<Customer> result =  from customer in customers       where customer.FirstName == "Donna“     select customer;

from后面是该查询语句的内部变量,where后面接条件,select接内部变量,result是查询结果

同时需注意result代表的不是当前数据库或数据的查询结果,而是代表这个查询过程,也就是说result后的结果在数据修改前后可能是不同的。

3. 当需要保存查询结果时,可以用 ToList () or the ToArray() 来保存当前查询的结果

IEnumerable<Customer> result =  from customer in customers       where customer.FirstName == "Donna“     select customer;

List<Customer> cachedResult = result.ToList<Customer>();

4. 对数据集合的操作:join(取交集), grouping(分组), aggregation(合并), and sorting.

 [data source 1] join [data source 2] on [join condition]

例如: from customer in customers        join address in addresses           on customer.Name equals address.Name   就是对客户名字与家庭地址相同的数据取交集

var result = from address in addresses

group address by address.Name;

注意分组之后的结果相当于一个二维数组

而对于排序:from customer in Customers        orderby customer.LastName        select customer 默认为升序

tips:对于select的变量如果未定义其类型,则可以用var交给编译器去推断。

5. Extension Methods可以简化查询语句,但是有很多限制

Lambda Expressions in LINQ : IEnumerable<Customer> result = customers.Where( customer =>  customer.FirstName == "Donna“ ) ;

XML

1. eXtensible Markup Language 的格式

2. 将数据库变为XML文档

该文档是Customers,里面的元素是Customer,每个Customer都有FirstName, LastName, EmailAdress。

3. XML的序列化与反序列化

XmlSerializer serializer = new XmlSerializer(typeof(Customer));

序列化之后的结果。数据需要序列化以后传输。

而反序列化是将一个接收到的XML转换为本地可处理的文本。

时间: 2025-01-17 14:31:34

C#之LINQ与XML的相关文章

24.C#LINQ TO XML(十二章12.3)

自己也写了那么多,但还有很多不懂,有点浮躁吧,但饭还是要吃啊,说说LINQ TO XML吧. LINQ TO XML位于System.Xml.Linq程序集,并且大多数类型位于System.Xml.Linq命名空间.该命名空间下几乎所有类型都以X为前缀;普通DOM API中的Element对应LINQ TO XML中的XElement.列举下都有哪些类型. XName:表示元素和特性的名称 XNamespace:表示XML的命名空间,通常是一个URL XObject:是XNode和XAttrib

LINQ to XML 编程基础

1.LINQ to XML类 以下的代码演示了如何使用LINQ to XML来快速创建一个xml: 隐藏行号 复制代码 ?创建 XML public static void CreateDocument() { string path = @"d:\website"; XDocument xdoc = new XDocument(new XDeclaration("1.0", "utf-8", "yes"), new XEle

XML读写利器XElement(Linq to xml)

年初公司绩效改革,在等最后通知,不知我有没理解错,感觉新版绩效最高会比原先最高拿到的奖金整整少一半... 还好同时也有调工资,加了一点.去年好像是年中整体调过一次,不知公司是一年调两次还是从今年开始改成年初调. 晚上去加班,处理一个数据交换,本想XML和实体直接互相转换,但XML结构太复杂,自动转换不理想,改用手工处理. 原先其它项目是用原始的XmlDocument,感觉不好用,写法也很不美观 网上说还有种XMLTextReader,像DataReader一样,向前只读的,从来没用过 以前有用过

Linq之Linq to XML

目录 写在前面 系列文章 linq to xml 总结 写在前面 在很多情况下,都可以见到使用xml的影子.例如,在 Web 上,在配置文件.Microsoft Office Word 文件(将word文档另存为xml文件,这也提供了一种通过操作xml,操作word的一种方式)以及数据库中,都可以看到 XML.而linq to xml提供了一种操作xml更便捷的方式. 系列文章 Linq之Lambda表达式初步认识 Linq之Lambda进阶 Linq之隐式类型.自动属性.初始化器.匿名类 Li

LINQ to XML(1)

LINQ to XML可以两种方式和XML配合使用.第一种方式是作为简化的XML操作API,第二种方式是使用LINQ查询工具.下面我使用的是第二种方式. 主要内容:用LINQ查询语句对XML文件里的数据进行筛选. 此方法优点: 1.我们可以使用单一语句自顶向下创建XML树. 2.我们可以使用包含树的XML文档在内存中创建并操作XML. 3.我们可以不适用Text子节点来创建和操作字符串节点. 4.一个最大的不同(改进)是,在搜索一个XML树时,不需要遍历它.相反只需要查询树并让它返回想要的结果.

LINQ to XML 实战

LINQ to XML 轴定义:创建XML树或将XML文档加载到XML树之后,可以进行查询,从而查找元素并检索它们的值. 两类轴方法:-一些轴就是XELement和XDocument类中返回IEnumerable(T)集合的方法.-另一些轴方法是Extensions类中的扩展方法.实现为扩展方法的轴对集合进行操作,然后返回集合.XContainer是XElement的基类! -常见的轴方法:-XContainer.Elements()返回集合 -XContainer.Descendants()返

Linq To XML 简单操作

加载xml文件和保存xml文件 XDocument doc = XDocument.Load(Server.MapPath("\\xmlfile\\Book.xml")); doc.Save(Server.MapPath("\\xmlfile\\BookBackup.xml")); 创建元素 XElement xe = new XElement("book",new XElement("bookname","asp.

Linq学习随笔二------LINQ to XML

LINQ to XML LINQ to XML provides an in-memory XML programming interface that leverages the .NET Language-Integrated Query (LINQ) Framework. LINQ to XML uses the latest .NET Framework language capabilities and is comparable to an updated, redesigned D

LINQ to XML编程之编程基础

1.声明,LINQ to XML让xml的创建变得非常简单. 1 XDocument myDocument = new XDocument( 2 new XDeclaration("1.0", "utf-8", "yes"), 3 new XElement("Root", "stuff") 4 ); 5 string str = myDocument.Declaration + Environment.Ne

Silverlight 使用IsolatedStorage新建XML文件,并且用LINQ查询XML

代码 Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->using System; using System.Linq; using System.Windows.Shapes; using System.Collections.Generic; using System.Collections.ObjectModel; using System.IO