zoukankan      html  css  js  c++  java
  • 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;
            }   
  • 相关阅读:
    团队冲刺(八)
    团队冲刺(七)
    团队冲刺(六)
    Java开发中BASE64Encoder的使用
    解决waiting for target deviceto come online的做法
    团队冲刺(五)
    团队冲刺(四)
    CSS布局 ——从display,position, float属性谈起
    让图表的Y轴 产生几个刻度距离
    CSS行高——line-height 垂直居中等问题
  • 原文地址:https://www.cnblogs.com/abcdwxc/p/1394076.html
Copyright © 2011-2022 走看看