您的位置:首页 > 数据库

基于Visual Studio2010讲解LINQ读出数据库数据生成XML

2010-05-20 14:54 274 查看
LINQ to XML 是一种启用了 LINQ 的内存 XML 编程接口,使用它,可以在 .NET Framework 编程语言中处理 XML。
LINQ to XML 最重要的优势是它与 Language-Integrated Query (LINQ) 的集成。 由于实现了这一集成,因此,可以对内存 XML 文档编写查询,以检索元素和属性的集合。 LINQ to XML 的查询功能在功能上(尽管不是在语法上)与 XPath 和 XQuery 具有可比性。 Visual C# 2008 集成 LINQ 后,可提供更强的类型化功能、编译时检查和改进的调试器支持。
通过将查询结果用作 XElement 和 XAttribute 对象构造函数的参数,实现了一种功能强大的创建 XML 树的方法。 这种方法称为“函数构造”,利用这种方法,开发人员可以方便地将 XML 树从一种形状转换为另一种形状。
LINQ to XML 提供了改进的 XML 编程接口,这一点可能与 LINQ to XML 的 LINQ 功能同样重要。 通过 LINQ to XML,对 XML 编程时,您可以实现任何预期的操作,包括:
从文件或流加载 XML。
将 XML 序列化为文件或流。
使用函数构造从头开始创建 XML。
使用类似 XPath 的轴查询 XML。
使用 Add、Remove、ReplaceWith 和 SetValue 等方法对内存 XML 树进行操作。
使用 XSD 验证 XML 树。
使用这些功能的组合,可将 XML 树从一种形状转换为另一种形状。
创建 XML 树是否方便,这一点非常重要。 例如,若要创建一个小型 XML 树,可以编写以下 C# 代码:
XElement contacts = new XElement("Contacts", new XElement("Contact", new XElement("Name", "Patrick Hines"), new XElement("Phone", "206-555-0144", new XAttribute("Type", "Home")), new XElement("phone", "425-555-0145", new XAttribute("Type", "Work")), new XElement("Address", new XElement("Street1", "123 Main St"), new XElement("City", "Mercer Island"), new XElement("State", "WA"), new XElement("Postal", "68042") ) ) );
请注意,缩进用于构造 XML 树的代码可显示基础 XML 的结构。
直接使用 XML 元素
在使用 XML 编程时,主要关注的通常是 XML 元素,也可能关注属性。 在 LINQ to XML 中,可以直接使用 XML 元素和属性。 例如,可以执行以下操作:
创建 XML 元素而根本不使用文档对象。 当必须使用 XML 树的片段时,这可简化编程。
直接从 XML 文件加载 T:System.Xml.Linq.XElement 对象。
将 T:System.Xml.Linq.XElement 对象序列化为文件或流。
使用 LINQ to XML 时,仅在文档的根级别添加注释或处理说明时,才需使用 XDocument
名称和命名空间的简化处理
处理名称、命名空间和命名空间前缀通常是 XML 编程的复杂部分。LINQ to XML 完全不需要处理命名空间前缀,从而简化了名称和命名空间。 可以轻松控制命名空间前缀。 但如果您决定不显式控制命名空间前缀,则在序列化时,LINQ to XML 将会分配命名空间前缀(如果需要)或使用默认命名空间进行序列化。 如果使用默认命名空间,则生成的文档中将没有命名空间前缀。
下面我们来看LINQ读出数据库数据生成XML实战例程:

本实例是一个从数据库里读出来省份,城市,地区的数据生成3个XML文件.

首先创建一个Linq to SQL的类, 然后将省份,城市,地区的表拖入类中:



然后新建一个类,加入代码如下:
public void ResetProvinces(string path)
{
XElement xmlProvinces = new XElement("Provinces");

foreach (S_Province province in DB.S_Provinces)
{
xmlProvinces.Add(
new XElement("Province", province.ProvinceName.ToString(),
new XAttribute("ID", province.ProvinceID.ToString()),
new XAttribute("ProvinceName", province.ProvinceName.ToString())
)
);
}

xmlProvinces.Save(@path);
}

public void ResetCities(string path)
{
XElement xmlCities = new XElement("Cities");

foreach (S_City city in DB.S_Cities)
{
xmlCities.Add(
new XElement("City", city.CityName.ToString(),
new XAttribute("ID", city.CityID.ToString()),
new XAttribute("CityName", city.CityName.ToString()),
new XAttribute("PID", city.ProvinceID.ToString()),
new XAttribute("ZipCode", city.ZipCode.ToString())
)
);
}

xmlCities.Save(@path);
}

public void ResetDistract(string path)
{
XElement xmlDistricts =new XElement("Districts");

foreach (S_District district in DB.S_Districts)
{
xmlDistricts.Add(
new XElement("District", district.DistrictName.ToString(),
new XAttribute("ID", district.DistrictID.ToString()),
new XAttribute("DistrictName", district.DistrictName.ToString()),
new XAttribute("CID", district.CityID.ToString())
)
);
}

xmlDistricts.Save(@path);
}


最后执行过代码后可以看到XML效果:

(以城市为例)
<?xml version="1.0" encoding="utf-8"?>
<Cities>
<City ID="1" PID="1" ZipCode="100000">北京市</City>
<City ID="2" PID="2" ZipCode="100000">天津市</City>
<City ID="3" PID="3" ZipCode="050000">石家庄市</City>
<City ID="4" PID="3" ZipCode="063000">唐山市</City>
<City ID="5" PID="3" ZipCode="066000">秦皇岛市</City>
<City ID="6" PID="3" ZipCode="056000">邯郸市</City>
<City ID="7" PID="3" ZipCode="054000">邢台市</City>
<City ID="8" PID="3" ZipCode="071000">保定市</City>
<City ID="9" PID="3" ZipCode="075000">张家口市</City>
<City ID="10" PID="3" ZipCode="067000">承德市</City>
<City ID="11" PID="3" ZipCode="061000">沧州市</City>
<City ID="12" PID="3" ZipCode="065000">廊坊市</City>
<City ID="13" PID="3" ZipCode="053000">衡水市</City>
<City ID="14" PID="4" ZipCode="030000">太原市</City>
<City ID="15" PID="4" ZipCode="037000">大同市</City>
<City ID="16" PID="4" ZipCode="045000">阳泉市</City>
<City ID="17" PID="4" ZipCode="046000">长治市</City>
<City ID="18" PID="4" ZipCode="048000">晋城市</City>
<City ID="19" PID="4" ZipCode="036000">朔州市</City>
<City ID="20" PID="4" ZipCode="030600">晋中市</City>
<City ID="21" PID="4" ZipCode="044000">运城市</City>
<City ID="22" PID="4" ZipCode="034000">忻州市</City>
<City ID="23" PID="4" ZipCode="041000">临汾市</City>
<City ID="24" PID="4" ZipCode="030500">吕梁市</City>
<City ID="25" PID="5" ZipCode="010000">呼和浩特市</City>
<City ID="26" PID="5" ZipCode="014000">包头市</City>
<City ID="27" PID="5" ZipCode="016000">乌海市</City>
</Cities>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: