动态选择并更新LINQ结果集中的列值

时间:2011-05-13 15:04:24

标签: c# asp.net linq-to-sql dynamic-linq

我有一个场景,其中存在LINQ结果集;我使用了以下查询

var stockDetails = from d in db.BloodBanks
                   where d.bbUserName == Session["username"].ToString()
                   select d;

现在我想使用此结果集并更新列的值。该列是通过字符串变量动态选择的。

我尝试使用的代码是:

foreach (BloodBank b in stockDetails)
            {
                b.<--column name from string variable--> = TextBox1.Text;
            }

请帮我解决一下这个问题。

2 个答案:

答案 0 :(得分:3)

您可以使用反射来按名称获取字段。

foreach (BloodBank b in stockDetails)
{
    FieldInfo f = typeof(BloodBank).GetField("fieldName");
    if (f != null)
    {
       f.SetValue(b, TextBox1.Text);
    }
}

答案 1 :(得分:1)

foreach (BloodBank b in db.BloodBanks.Where(d => where d.bbUserName == Session["username"].ToString())
{
    b.col = TextBox1.Text;
}