• IList转化为Dataset C#


    概述:

       在用Nhibernate查询所返回的数据为IList,而我们经常需要的却是DataSet,所以很有必要这么一个方法.

    代码:  

    /**/
            
    /// <summary>  
            
    /// 实现对IList到DataSet的转换   
            
    /// </summary>  
            
    /// <param name="list">待转换的IList</param>  
            
    /// <returns>转换后的DataSet</returns>  
            public static DataSet ListToDataSet(IList list)
            {
                DataSet ds 
    = new DataSet();
                DataTable dt 
    = new DataTable();

                
    //此处遍历IList的结构并建立同样的DataTable   
                System.Reflection.PropertyInfo[] p = list[0].GetType().GetProperties();
                
    foreach (System.Reflection.PropertyInfo pi in p)
                {
                    dt.Columns.Add(pi.Name, System.Type.GetType(pi.PropertyType.ToString()));
                }

                
    for (int i = 0; i < list.Count; i++)
                {
                    ArrayList arrayList 
    = new ArrayList();
                    
    //将IList中的一条记录写入ArrayList   
                    foreach (System.Reflection.PropertyInfo pi in p)
                    {
                        
    object obj = pi.GetValue(list[i], null);
                        arrayList.Add(obj);
                    }

                    
    object[] item = new object[p.Length];
                    
    //遍历ArrayList向object[]里放数据   
                    for (int j = 0; j < arrayList.Count; j++)
                    {
                        item.SetValue(arrayList[j], j);
                    }
                    
    //将object[]的内容放入DataTable   
                    dt.LoadDataRow(item, true);
                }
                
    //将DateTable放入DataSet   
                ds.Tables.Add(dt);

                
    //返回DataSet   
                return ds;
            }   
  • 相关阅读:
    MongoDB在windows服务器安装部署及远程连接MongoDB
    react 常用组件
    react component 语法报错解决
    yarn install node-sass(gulp-sass) 安装失败解决方案
    eslint 规则中文注释
    react jsx 代码格式化
    vue sublime 工欲善其事,必先利其器
    jenkins 配置
    nodejs 使用 superagent 与 cheerio 完成简单爬虫
    jQuery DOM对象区别与联系
  • 原文地址:https://www.cnblogs.com/abcdwxc/p/1394076.html
Copyright © 2020-2023  润新知