C#数据库查询结果赋值给对象

本文介绍了一种使用C#反射机制实例化对象并从数据表中读取数据来设置对象属性的方法。该方法遍历指定类型的所有属性,并根据数据表中的列名和值为这些属性赋值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

类中的成员变量的定义 private int var{get;set;}
 <param name="var_obj">需要赋值的对象</param>
 <param name="var_dt">需要赋值的数据表</param>

public static object DBObject(object var_obj, DataTable var_dt) { object obj= var_obj; DataTable dt = var_dt; Type type = typeof(User); System.Reflection.PropertyInfo[] minfos = type.GetProperties(); foreach (PropertyInfo minfo in minfos) { Console.WriteLine("item " + minfo.Name); } for (int i = 0; i < dt.Columns.Count; i++) { Console.WriteLine(dt.Columns[i].ColumnName.ToLower()); Console.WriteLine(dt.Rows[0][i].ToString()); var value = dt.Rows[0][i]; if (minfos[i].PropertyType == typeof(string)) { minfos[i].SetValue(obj, value.ToString()); string ttt = minfos[i].GetValue(obj).ToString(); } if (minfos[i].PropertyType == typeof(int)) { minfos[i].SetValue(obj, Convert.ToInt32(value)); string ttt = minfos[i].GetValue(obj).ToString(); } } Console.WriteLine(obj.ToString()); return obj;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值