使用LINQ to XML来查询XML

开发 数据库
语言集成查询(LINQ to XML)简化了对XML数据的使用,不必使用额外的语言语法像XPath或XQuery。你可以使用它对你从文件系统、从一个远程web service或从一个内存中的XML内容中获得的XML执行LINQ查询。本文将只关注于使用LINQ从一个XML文件——Customers.xml文件查询XML。

用于XML的语言集成查询(LINQ to XML)允许使用标准查询操作符就像树形操作符一样来查询XML数据,它能够提供类似XPath的导航在后代、祖先和兄弟的XML元素中导航。它简化了对XML数据的使用,不必使用额外的语言语法像XPath或XQuery。你可以使用LINQ to XML对你从文件系统、从一个远程web service或从一个内存中的XML内容中获得的XML执行LINQ查询。这篇文章将只关注于使用LINQ从一个XML文件——Customers.xml文件查询XML。

创建一个简单的LINQ项目

我们将命名我们的Visual Studio项目为ConsoleLINQtoXML,并使用C#语言。使用using 指令添加下面的命名空间。System.Xml.Linq命名空间包含LINQ to XML所用到的类。

 //Include the LINQ to XML namespaces
  using System.Xml; //namespace to deal with XML documents

  using System.Xml.Linq; //namespace to deal with LINQ to XML classes

接下来,我们将在我们的项目中添加Customers.xml文件。你也可以选择将这个XML文件存储在你的文件系统中的一个目录下,但是为了简单起见,我们将只把它包含进我们的项目。在Visual Studio中点击Project菜单并选择Add Existing Item...。

 
图1

选择Customers.xml文件并点击Add。这个XML文件将被添加到你的项目中。

 
图2

从Solutions Explorer右键单击文件Customers.xml并选择Properties。这将显示Properties窗口。

 
图3

在Customers.xml文件的Properties窗口中,点击Copy to Output Directory选项并从下拉列表框中选择Copy always。

 
图4

现在我们开始编写LINQ查询来读取我们的XML文件。首先在static void Main(string[] args)中编写一些代码。

// Create the query
  var custs = from c in XElement.Load("Customers.xml").Elements("Customers")
   select c ;
   // Execute the query
   foreach (var customer in custs)
   {
   Console.WriteLine(customer);
   }
   //Pause the application
   Console.ReadLine();

你将注意到它是使用XElement类来显示XML元素。XElement类的Load方法很简单地将Customers.xml文件加载到XElement类中去。Elements方法返回XML文档中这个元素——Customers元素——的一个过滤的子元素集合。这只是显示了LINQ是多么强大,因为你对集合使用相同的语言查询构造而现在是对XML文档。你甚至可以执行排序、过滤和分组如同你平常在LINQ中所做的。你可以插入一个where条件从句到上面的查询中来过滤你的结果。

where c.Element("Country").Value == "Italy"

当你在Visual Studio中运行你的项目时,你的输出将看起来如下所示。你可以点击F5或点击Visual Studio中的Debug - Start Debugging来运行。

 
图5

不使用LINQ来做相同的事情是要复杂得多,因为你仍然需要在节点间搜索以访问这些元素和它们的值。

【编辑推荐】

  1. XML结构与语法入门详解
  2. 解析JSP与XML交互编程的技巧
  3. Spring中XML配置的12个技巧
  4. 基于XML和JSON设计的Flex
责任编辑:杨鹏飞 来源: IT专家网
相关推荐

2009-09-16 15:41:45

LINQ查询XML文档

2011-07-22 08:43:08

XML

2009-09-17 13:54:26

LINQ to XML

2009-09-14 16:46:15

LINQ to XML

2009-09-16 16:59:05

LINQ to XML

2009-09-14 16:41:23

LINQ To XML

2011-07-26 13:58:17

LINQ

2009-09-16 16:52:50

LINQ to XML

2009-09-16 15:33:22

LINQ to XML

2009-09-14 15:12:40

LINQ to XML

2009-09-17 13:30:32

LINQ to XML

2009-09-14 16:33:55

LINQ To XML

2009-09-08 16:55:01

Linq实现XML转换

2009-09-16 16:55:07

LINQ to XML

2009-09-16 15:53:49

Linq创建xml文档

2009-09-17 13:38:42

LINQ to XML

2009-09-14 14:58:52

LINQ to XML

2009-09-14 16:17:03

什么是LINQ To

2009-09-14 16:51:33

LINQ XML树加载

2009-09-14 15:45:28

LINQ删除XML节点
点赞
收藏

51CTO技术栈公众号