将DataTable与DataView转换成DataSet(示例)

今天遇到这样的事情。将DataSet的视图传递给DataView,对DataView进行了数据排序。然后想将 DataView再放到DataSet中。却发现,DataSet的视图状态是不可以赋值的。即是只读状态。

 当然头一个反应就是到百度上去搜索。以“DataView转换成DataSet”的关键字作为查找。当然显示的结果很令人满意。查到了NNNN多。欣然打开链接。哈哈,这个链接就到了csdn上了。楼主朋友遇到了和我一样的问题,热心的朋友在那热心的留言帮助。总结各位热心朋友的解释。“DataView转换成DataSet”那是不可能的。(我就不信,肯定有个解决的方法)。

    于是在百度上不断的点链接,突然看到“DataView 这样的对象保存到 XML 实”!心里那个激动啊。马上点开链接。原来是msdn啊,终于找到官方的解释了。

   说了这么多废话。马上进入主题——————————————》》》》》

    ADO.NET 框架只对 DataSet 对象提供显式 XML 支持。不过,将 DataView 或 DataTable 转换为 XML 并不是特别难。在这两种情况下,您都必须使用临时的数据集作为要另存为 XML 的行集的容器。用于将 DataTable 保存为 XML 所必需的代码很简单。

以下是我做的一个示例。

1、用dataset读取。xml文件。

2、将dataset视图传给DataView,并对DataView进行排序。

3、将DataView的table传递给DataTable。

4、将DataTable添加给DataSet。然后用DataSet重新写入XML文件

 

user.xml文件内容

 

<? xml version="1.0" encoding="gb2312" ?>
< user >
  
< person  name ="name1" >
    
< sex > M </ sex >
    
< age > 15 </ age >
    
< pass > 1234 </ pass >
    
< Address > 浙江杭州 </ Address >
  
</ person >
  
< person  name ="fast" >
    
< sex > F </ sex >
    
< age > 25 </ age >
    
< pass > 5dfdfjsl </ pass >
    
< Address > 杭州拱墅区 </ Address >
  
</ person >
  
< person  name ="tom" >
    
< sex > M </ sex >
    
< age > 23 </ age >
    
< pass > 放电放电 </ pass >
    
< Address > 绍兴新昌 </ Address >
  
</ person >
  
< person  name ="charli" >
    
< sex > F </ sex >
    
< age > 34 </ age >
    
< pass > 大幅度放电 </ pass >
    
< Address > 台州 </ Address >
  
</ person >
  
< person  name ="jimm" >
    
< sex > F </ sex >
    
< age > 54 </ age >
    
< pass > 东方路djwoomldm </ pass >
    
< Address > 舟山东路 </ Address >
  
</ person >
  
< person  name ="frinm" >
    
< sex > M </ sex >
    
< age > 35 </ age >
    
< pass > 23fds </ pass >
    
< Address > beijing china  </ Address >
  
</ person >
  
< person  name ="agui" >
    
< sex > F </ sex >
    
< age > 36 </ age >
    
< pass > 辅导室阀 </ pass >
    
< Address > 魅力的中国 </ Address >
  
</ person >
< person  name ="one" >
    
< sex > F </ sex >
    
< age > 3 </ age >
    
< pass > 辅导室阀 </ pass >
    
< Address > 魅力的中国 </ Address >
  
</ person >
< person  name ="three" >
    
< sex > F </ sex >
    
< age > 300 </ age >
    
< pass > 辅导室阀 </ pass >
    
< Address > 魅力的中国 </ Address >
  
</ person >
</ user >

 

CS代码

 

using  System;
using  System.Data;
using  System.Configuration;
using  System.Collections;
using  System.Web;
using  System.Web.Security;
using  System.Web.UI;
using  System.Web.UI.WebControls;
using  System.Web.UI.WebControls.WebParts;
using  System.Web.UI.HtmlControls;
using  System.Xml;
using  System.IO;

public   partial   class  Sort : System.Web.UI.Page
{
    
protected void Page_Load(object sender, EventArgs e)
    
{
        DataSet ds 
= new DataSet();
        ds.ReadXml(Server.MapPath(
"user.xml"));
        DataColumn dc 
= new DataColumn("Sort");
        dc.DataType 
= typeof(int);
        ds.Tables[
0].Columns.Add(dc);

        
for (int i = 0; i < ds.Tables[0].Rows.Count;i++ )
        
{
            ds.Tables[
0].Rows[i]["Sort"= ds.Tables[0].Rows[i]["age"];
        }

        
int ordinal = ds.Tables[0].Columns["age"].Ordinal;
        ds.Tables[
0].Columns.Remove("age");
        ds.Tables[
0].Columns["Sort"].ColumnName = "age";
        ds.Tables[
0].Columns["age"].SetOrdinal(ordinal);
        DataView dv
=new DataView();
        dv 
= ds.Tables[0].DefaultView;
        dv.Sort 
= "age asc";
        
this.Gridview1.DataSource = dv;
        
this.Gridview1.DataBind();
        WriteDataTableToXml(Server.MapPath(
"."+ "/shengcheng.xml", DataViewToDataTable(dv));

        ds 
= new DataSet();
        ds.ReadXml(Server.MapPath(
"shengcheng.xml"));
        dv 
= ds.Tables[0].DefaultView;
        
this.Gridview2.DataSource = dv;
        
this.Gridview2.DataBind();

    }


   
public DataTable DataViewToDataTable(DataView dv)
    
{
        
//Clone dv.Table to dtTemp
        DataTable dtTemp = dv.Table.Clone();
        dtTemp.TableName 
= "Row";   

        
foreach (DataRowView drv in dv)
            dtTemp.ImportRow(drv.Row);
        
return dtTemp;
    }


   
public void WriteDataTableToXml(String fileName, DataTable dt)
    
{
        DataSet dsTmp 
= new DataSet();
        DataTable dtTmp 
= dt.Copy();
        dsTmp.Tables.Add(dtTmp);

        StreamWriter sr 
= new StreamWriter(fileName);
        dsTmp.WriteXml(sr);
        sr.Close();
    }

//    protected int Sort {
//    int get ();
//    void set (String value);
//}




}

 

Sort.aspx

 

% @ Page Language = " C# "  AutoEventWireup = " true "  CodeFile = " Sort.aspx.cs "  Inherits = " Sort "   %>

<! DOCTYPE html PUBLIC  " -//W3C//DTD XHTML 1.0 Transitional//EN "   " http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd " >

< html xmlns = " http://www.w3.org/1999/xhtml "   >
< head runat = " server " >
    
< title > 无标题页 </ title >
</ head >
< body >
    
< form id = " form1 "  runat = " server " >
    
< div >
    从旧文件读取排序后显示的文件格式
    
< asp:gridview ID = " Gridview1 "  runat = " server " ></ asp:gridview >
    
    
< br  />
   
< font color = red >  从新文件读取没有排序后显示的文件格式 </ font >
    
< asp:gridview ID = " Gridview2 "  runat = " server " ></ asp:gridview >
    
</ div >
    
</ form >
</ body >
</ html >

 

在此特别说一句,datatable在asp.net2.0中已经支持对xml文件的读写操作了

对于以上还用dataset来操作主要是参照了asp.net1.1中的做法

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值