Datatable C#使用中DataRow中的列名是不区分大小的

在C#中,虽然语法区分大小写,但DataTable的DataRow在处理列名时并不区分大小写。这使得在动态转换模型时,即使列名大小写不一致,也能正确匹配。以下是相关的代码示例,推荐使用这种不区分大小写的写法进行操作。
摘要由CSDN通过智能技术生成

工作中看到一段需要动态转换模型的代码,当数据比较多的时候,效率会慢,经过试验C# 虽然区分大小写,但在Datarow中是模糊了的,遂意为C#还是很好用的。示例Demo如下,推荐第二种写法。
推荐写法:

        public static List<T> DataTableToList2<T>(DataTable dt)
        {
            List<T> lists = new List<T>();
            for (int i = 0; i < dt.Rows.Count; i++)
            {
                T t = Activator.CreateInstance<T>();
                //获取当前T对象的所有属性
                PropertyInfo[] propertys = t.GetType().GetProperties();
                //通过属性集合迭代出每一个属性对象
                foreach (PropertyInfo item in propertys)
                {
                    int index = dt.Columns.IndexOf(item.Name);// datatable 中列名不区分大小写,
                    if (index>=0)//dt.Columns.Contains(item.Name),用index读取值速度要更好一些
                    {
                        //判断当前DataTable的单列值是否为null
                        if (dt.Rows[i][index] != DBNull.Value)
                            //将当前DataTable的单列值赋予相匹配的属性,否则赋予一个null值.
                            item.SetValue(t, (dt.Rows[i][index]), null);
                        else
                            item.SetValue(t, null, null);

                    }

                }
                lists.Add(t);
            }
            return lists;
        }

懒得分开写,直接写代码吧:


    public class TmpMode
    {
        public string AAA { get; set; }
        public string BBB { get; set; }
        public string c { get; set; }
        public string AAA1 { get; set; }
        public string BBB2 { get; set; }
        public string AAA3 { get; set; }
        public s
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值