利用反射把DataTable的数据写到集合实体类里

//使用原因 :在程序运行时,数据库数据直接加载到本地内存,可以提高程序的运行效率

//定义类型

public class hospital

{
        public string KeHuHospitalCode { get; set; }
         public string KeHuHospitalName { get; set; }

}

//客户医院查询数据
 if (list_hospital == null)

 {

     //从数据库获取所需要的数据,只能是2个字段的数据,名称必须为  KeHuHospitalCode ,KeHuHospitalName 

      DataTable dt = new BasicDAO().Get_DR_DouBao_Hostpital ();
      list_hospital = CommonMe.DataTableHelper.ToListEntity<hospital>(dt);

 }

//方法如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Reflection;

namespace CommonMe
{
    public static class DataTableHelper
    {

        #region 利用反射把DataTable的数据写到集合实体类里
        public static List<T> ToListEntity<T>(this DataTable dtSource)
        {
            List<T> list = new List<T>();
            if (dtSource == null)
            {
                return null;
            }


            Type type = typeof(T);
            List<string> arrayColumn = GetColumnsByDataTable(dtSource);
            foreach (DataRow dataRow in dtSource.Rows)
            {


                Object entity = Activator.CreateInstance(type); //创建实例  
                PropertyInfo[] listPro = type.GetProperties(BindingFlags.Public | BindingFlags.Instance);//Instance|Public:获取公共的的实例属性(非静态的)  Static|Public:获取公共的静态属性  Instance|Static|Public:获取公共的的实例或静态属性
                foreach (PropertyInfo entityCols in listPro)
                {
                    string columnName = arrayColumn.Where(a => a.ToUpper() == entityCols.Name.ToUpper()).FirstOrDefault();//不区分大小写
                    if (columnName != null && columnName != "")
                    {
                        object cellvalue = dataRow[columnName];


                        if (columnName != null
                            && dataRow[columnName] != null && dataRow[columnName] != DBNull.Value
                            )
                        {
                         
                            if (!entityCols.PropertyType.IsGenericType)
                            {
                                entityCols.SetValue(entity, Convert.ChangeType(cellvalue, entityCols.PropertyType), null);
                            }
                            else
                            {


                                Type genericTypeDefinition = entityCols.PropertyType.GetGenericTypeDefinition();
                                if (genericTypeDefinition == typeof(Nullable<>))
                                {
                                    entityCols.SetValue(entity, Convert.ChangeType(cellvalue, Nullable.GetUnderlyingType(entityCols.PropertyType)), null);
                                }
                            }
                        }
                    }
                }


                list.Add((T)entity);
            }


            return list;
        }


        #endregion


        public static List<string> GetColumnsByDataTable(DataTable dt)
        {
            List<string> strColumns = new List<string>();


            if (dt != null && dt.Columns.Count > 0)
            {
                for (int i = 0; i < dt.Columns.Count; i++)
                {
                    strColumns.Add(dt.Columns[i].ColumnName);
                }
            }
            return strColumns;
        }
    }

}

}


对于"c"这个字符,它在计算机科学中有着重要的地位。 首先,它是一种编程语言。C语言是一种广泛使用的、高效的程序设计语言。它具有简单、灵活、高效的特点,能够进行底层的内存操作和指针运算。C语言被广泛用于系统开发、嵌入式系统、操作系统等领域。 其次,它是一种数据型。在C语言中,"c"可以表示字符型。字符型是一种用于存储单个字符的数据型,它能够存储ASCII码或Unicode码中的字符。在C语言中,我们可以使用字符数据型来处理文本数据、实现输入输出等功能。 另外,"c"还代表了指针。指针是C语言中一个重要的概念,它存储了一个变量或对象的内存地址。通过使用指针,我们可以实现对内存的直接访问和操作。指针在C语言中具有重要的作用,它使得我们可以更灵活地管理内存,并实现一些高级的数据结构和算法。 此外,"c"还可以代表C标准库。C标准库是C语言的一个重要组成部分,它包含了大量的函数和常量,能够实现各种功能,例如输入输出、数学计算、内存管理等。C标准库提供了一些常用的函数供开发人员使用,能够简化程序的开发过程。 总的来说,"c"在计算机科学中有着重要的地位。它代表了一种编程语言、一种数据型、一种指针操作以及C标准库。掌握"C",能够帮助我们进行程序设计、内存管理和算法实现等方面的工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值