DataTable(SQL结果)转实体对象(Linq结果)

        public List<TResult> SqlQueryForTable222<TResult>(string sql, params object[] paras) where TResult : new()
        {
            SqlConnection conn = new System.Data.SqlClient.SqlConnection();
            conn.ConnectionString = _context.Database.Connection.ConnectionString;
            if (conn.State != ConnectionState.Open)
            {
                conn.Open();
            }
            SqlCommand cmd = new SqlCommand();
            cmd.Connection = conn;
            cmd.CommandText = sql;


            if (paras != null && paras.Length > 0)
            {
                foreach (var item in paras)
                {
                    cmd.Parameters.Add(item);
                }
            }
            SqlDataAdapter adapter = new SqlDataAdapter(cmd);
            DataTable table = new DataTable();
            adapter.Fill(table);


            #region DataTable转换为实体类型
            Collection<TResult> collection = null;  //定义实体类集合
            if (table != null)
            {
                Collection<System.Reflection.PropertyInfo> properties = new Collection<System.Reflection.PropertyInfo>();  //定义属性集合
                Type type = typeof(TResult);
                Array.ForEach<System.Reflection.PropertyInfo>(type.GetProperties(), p =>
                {
                    if (table.Columns.IndexOf(p.Name) != -1) { properties.Add(p); }
                });
                collection = new Collection<TResult>();
                foreach (DataRow row in table.Rows)   //循环DataTable的每行
                {
                    TResult result = new TResult();
                    foreach (System.Reflection.PropertyInfo p in properties)  //循环实体类的属性
                    {
                        object value = row[p.Name];  //根据实体类属性名,找到值并赋值
                        if (value != DBNull.Value)  //如果有值
                        {
                            Type schemaType = table.Columns[p.Name].DataType;  //根据此实体类属性名, 获取DataTable行的类型
                            if (schemaType != p.PropertyType)  //如果类型不相等
                            {
                                try
                                {
                                    value = Convert.ChangeType(row[p.Name], p.PropertyType);  //强转类型,并将类型赋给value
                                }
                                catch
                                {
                                    continue;
                                }
                            }
                            p.SetValue(result, value, null);   //赋值给实体类的value字段
                        }
                    }
                    collection.Add(result);  //将实体类对象放入
                }
            }
            #endregion


            IEnumerable<TResult> iEnum = collection;
            List<TResult> reult = iEnum.ToList();
            return reult;
        }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

willgon123

谢谢打赏,我将再接再厉!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值