日期:2014-05-17  浏览次数:20891 次

如何将不明确表数也不明确各表的列的DataSet转换为类
例如:
这次DataSet ds_test下有两个DataTable
dt_001,dt_002
dt_001的列为:
dc_001,dc_002,dc_003
dt_002的列为:
dc_001,dc_002,dc_003,dc_004

如何将这个DataSet转换为以下内容


    public class dt_001
    {
        public string dc_001{ get; set; }
        public string dc_002{ get; set; }
        public string dc_003{ get; set; }
    }
    public class dt_002
    {
        public string dc_001{ get; set; }
        public string dc_002{ get; set; }
        public string dc_003{ get; set; }
        public string dc_004{ get; set; }
    }
    
    public class ds_test
    {
        public List<dt_001>{ get; set; }
        public List<dt_002>{ get; set; }
    }

最后的结果中,就把这个DataSet的数据存到这一个ds_test类里面了
问题:接口给过来的DataSet中有多少表,不确定,每个表有多少列,不确定。但是要能通吃这个DataSet
琢磨半天都琢磨不出,望高手指点指点,给个相应的链接什么的。
如果分少 可以加分。

------解决方案--------------------
"ds_test类"
这个是编译前的代码段,编译之后就是"静态"的了.
去了解一下.net的MetaData就知道.

"接口给过来的DataSet中有多少表,不确定,每个表有多少列,不确定。但是要能通吃这个DataSet"
DataSet是运行时产生的数据,如果内容格式都不定,肯定不存在一个静态的已经写入到MetaData的类来匹配这个动态数据.

如果楼主真的想要这个效果,就需要动态生成ds_test类,在DataSet尝试数据时,动态编译,反射调用.

这种方法,编码难度、调试与除错都比静态编译的代码难度高。

我不知道为什么楼主会有这种需求。

是否是理解需求--> 设计出现了问题?



------解决方案--------------------
其实目的就是把DataSet中的DataTable转换成一个个List,
因为DataTable占用的内存比List会小很多
-----------------------------------------------------

说反了,list占内存小。

动态生成datatable对应的实体类型有难度。。。

要说为了不占内存,倒不如用List<object[]>:
foreach(DataRow row in ds.Table[0].Rows){
   list.Add(row.ItemArray);
}
------解决方案--------------------
引用:
例如:
这次DataSet ds_test下有两个DataTable
dt_001,dt_002
dt_001的列为:
dc_001,dc_002,dc_003
dt_002的列为:
dc_001,dc_002,dc_003,dc_004

如何将这个DataSet转换为以下内容


 &n