如何在c#中为查询添加额外的值

时间:2013-03-25 07:28:24

标签: c# linq lambda

我有这样的查询

var values = ProjectContext.controloptions.Where(i => i.id == id).Select(i => new {

          i.value
        }).ToList();

现在这些值包含4条记录,我想再添加2条记录,如

  values.Insert(0, new { "Select" });
  values.Add("AddNew");

但它显示错误。其中i.value是数据库中的varchar字段。

如何在没有额外字段的情况下将两条记录添加到列表中。

1 个答案:

答案 0 :(得分:1)

您正在选择匿名类型。您只能通过匹配属性及其类型的名称来添加此类型的另一个对象,如下所示:

var values = new[]{ new Options{value = 666, id = 5}} //array to demo purposes
                .Where(i => i.id == 5)
                .Select(i => new {
                              value = i.value.ToString()
                })
                .ToList();

values.Add(new {value = "Select"}); 
values.Insert(0, new {value = "AddNew"});

现在values包含三个匿名类型的对象(类型为value的一个属性string)并且可以打印为

AddNew 
666 
Select 

考虑创建新的自定义类,然后在Select投影中使用它,如下所示:

class MyCustomClass
{
    public string Value { get; set; }
}

然后在Select

中创建此对象
List<MyCustomClass> values = new[]{ new Options{value = 666, id = 5}}
                .Where(i => i.id == 5)
                .Select(i => new MyCustomClass {
                              Value = i.value.ToString()
                    })
                .ToList();

values.Add(new MyCustomClass { Value = "Select"});              
values.Insert(0, new MyCustomClass { Value = "AddNew"});

现在你的List名为List<MyCustomClass>,并且可以使用命名类添加和删除元素