Asp.Net教程,WinForm教程,Asp.Net MVC,vs2008教程,vs2010教程,Silverlight技术,源码下载,Asp.Net视频教程
全站热门标签
vs2010 Silverlight 存储过程 水晶报表 ADO.NET JavaScript LINQ AjaxPro DataGridView 面向对象 Extjs GridView XML DevExpress HTML教程 Oracle jQuery 分页 GDI+ Visual C++2010 MySQL Office2010 WPF MVC Dojo WCF4.0 VB.NET Sql2005 textbox cookie WCF WinForm Discuz!NT SQL经典语句 T-SQL checkbox ASPxGridView F# asp.net SQL VS2008新特性 DropDownList Access TreeView Ajax VS2008 页面执行时间 Flex 字符串 回调 VB2005 DataSet C#时间 ASP.NET性能优化 用户在线检测 动画
当前位置: 主页 > vs2010教程 >

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

时间:2010-08-06 18:48来源:未知 作者:admin 点击:

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> 

(责任编辑:admin)
Tags:XML vs2010 LINQ
责任编辑:admin
返回顶部
------分隔线----------------------------
推荐内容
骆驼户外男 真皮磨砂日常休闲鞋 低帮 2011秋冬新款 专柜正品特价 骆驼户外男 真皮磨砂日常休闲鞋 低帮 2011秋冬新款 专柜正品特价