将DataTable与DataView转换成DataSet(示例)
2007-08-31 09:18
447 查看
今天遇到这样的事情。将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>
当然头一个反应就是到百度上去搜索。以“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与DataView转换成DataSet(示例)
- 将DataTable与DataView转换成DataSet(示例)
- 转载把DataSet、DataTable、DataView格式转换成XML字符串、XML文件
- XML格式与DataTable、DataSet、DataView格式的转换
- (转)XML格式与DataTable、DataSet、DataView格式的转换
- ASP.NET中DataTable与DataSet之间的转换示例
- 转载把DataSet、DataTable、DataView格式转换成XML字符串、XML文件
- XML格式与DataTable、DataSet、DataView格式的转换
- 转载把DataSet、DataTable、DataView格式转换成XML字符串、XML文件
- DataSet、DataTable、DataView格式与XML字符串、XML文件互相转换(转载)
- XML格式与DataTable、DataSet、DataView格式的转换
- 数据绑定技术_单值数据绑定示例;将 DataTable,DataSet,DataView,DataReader 绑定到 DataGrid 控件示例;DataBinder.Eval;数组的值赋给ListBox1;Hashtable 绑定到;RadioButtonList;将XML 文件做为数据源绑定到控件
- XML格式与DataTable、DataSet、DataView格式的转换
- 转载把DataSet、DataTable、DataView格式转换成XML字符串、XML文件
- XML格式与DataTable、DataSet、DataView格式的转换
- DataSet、DataTable、DataView格式转换成XML字符串、XML文件
- 关于DataSet、DataView、DataTable、DataRow、时间格式转换的一些用法
- ASP.NET中DataTable与DataSet之间的转换示例
- DataTable、DataView、DataSet 区别
- dataTable 、dataView、Dataset 区别的经典回答