ASP.NET生成XML的一些方法
创始人
2024-06-06 05:41:45
0

ASP.NET生成XML是一种比较常见的功能,XML可以传递更多的数据与信息。这里的ASP.NET生成XML将从业务逻辑层、数据访问层、表示层入手,以代码的形式进行展现。

1.业务逻辑层:

  1. public DataSet ABCData()  
  2.         {  
  3.             DataBase db = new DataBase();  
  4.             string sql = "select * from products where products_Year='2008'";  
  5.             DataSet ds = db.GetDataSet(sql);  
  6.             return ds;  
  7.         } 

注sql执行结果:

produts_Id products_Name products_Quantity products_Year
38          AAA            7649               2008
39          BBB            4567               2008
40          CCC            6410               2008

2.数据访问层略:

3.表示层:

  1. protected void Page_Load(object sender, EventArgs e)  
  2.     {  
  3.         DataBind databind=new DataBind ();  
  4.         DataSet ds=databind.ABCData();  
  5.  
  6.         string plot_type = "CategorizedVertical";  
  7.         XmlDocument doc = new XmlDocument();  
  8.         XmlElement Node = doc.CreateElement("anychart");//创建一个anychart节点  
  9.         doc.AppendChild(Node);  
  10.  
  11.         XmlElement Node1 = doc.CreateElement("charts");//创建节点anychart子节点charts  
  12.         doc.DocumentElement.AppendChild(Node1);  
  13.  
  14.         XmlElement Node2 = doc.CreateElement("chart");//创建节点charts子节点chart  
  15.         Node2.SetAttribute("plot_type", plot_type);//为节点chart添加plot_type属性  
  16.         Node1.AppendChild(Node2);  
  17.  
  18.         XmlElement Node3 = doc.CreateElement("data");//创建节点chart***个子节点data  
  19.         Node2.AppendChild(Node3);  
  20.  
  21.         XmlElement Node4 = doc.CreateElement("chart_settings");//创建节点chart第二个子节点chart_settings  
  22.         Node2.AppendChild(Node4);  
  23.  
  24.         XmlElement Node5 = doc.CreateElement("series");//创建节点data子节点series  
  25.         Node5.SetAttribute("name", "Year 2003");//为series节点添加***个属性name  
  26.         Node5.SetAttribute("type", "Bar");//为series节点添加第二个属性type  
  27.         Node3.AppendChild(Node5);  
  28.         for (int i = 1; i <= 3;i++ )  
  29.         {  
  30.             XmlElement Node13 = doc.CreateElement("point");//在节点series中创建子节点point  
  31.             Node13.SetAttribute("name", ds.Tables[0].Rows[i - 1]["products_Name"].ToString());//为point节点添加属性name并将ds.Tables[0]中products_Name一列数据逐行取出,赋值给属性name  
  32.             Node13.SetAttribute("y", ds.Tables[0].Rows[i - 1]["products_Quantity"].ToString());//为point节点添加属性y并将ds.Tables[0]中products_Quantity一列数据逐行取出,赋值给属性y  
  33.             Node5.AppendChild(Node13);  
  34.         }  
  35.  
  36.         XmlElement Node6 = doc.CreateElement("title");  
  37.         Node4.AppendChild(Node6);  
  38.  
  39.         XmlElement Node7 = doc.CreateElement("axes");  
  40.         Node4.AppendChild(Node7);  
  41.  
  42.         XmlElement Node8 = doc.CreateElement("y_axis");  
  43.         Node7.AppendChild(Node8);  
  44.  
  45.         XmlElement Node9 = doc.CreateElement("x_axis");  
  46.         Node7.AppendChild(Node9);  
  47.  
  48.         XmlElement Node10 = doc.CreateElement("title");  
  49.         Node10.InnerText = "Sales";//为节点title赋值Sales  
  50.         Node8.AppendChild(Node10);  
  51.  
  52.         XmlElement Node11 = doc.CreateElement("title");  
  53.         Node11.InnerText = "Retail Channel";  
  54.         Node9.AppendChild(Node11);  
  55.  
  56.         XmlElement Node12 = doc.CreateElement("text");  
  57.         Node12.InnerText = "销售";  
  58.         Node6.AppendChild(Node12);  
  59.         doc.Save(Server.MapPath("test.xml")); //保存xml   
  60.     } 

4.生产的xml:

  1.  
  2.  
  3.      
  4.        
  5.          
  6.            
  7.            
  8.            
  9.          
  10.        
  11.        
  12.          <LI class=alt>          <text>销售<text> <LI class="">         
  13.          
  14.            
  15.             Sales 
  16.            
  17.            
  18.             Retail Channel 
  19.            
  20.          
  21.        
  22.      
  23.  
  24.  

ASP.NET生成XML的一些方法就介绍到这里吧。

原文标题:ASP.NET生成层次较复杂的XML

链接:http://www.cnblogs.com/jiaojiaojojo/archive/2009/09/04/1559963.html

【编辑推荐】

  1. 深入研究Repeater控件:***的灵活性
  2. DataList控件入门介绍
  3. DataGrid Web控件运作机制探秘
  4. 小议ASP.NET数据Web控件之间的相似性
  5. 从传统ASP到ASP.NET的转变:了解控件

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...