当对象具有集合属性</object>时,自动映射在投影IQueryable <object>时失败

时间:2012-04-24 04:49:01

标签: c# .net automapper

所以,这是我的情况。我有两个课程:

class FromClass
{
    public string[] Foo { get; set; }
}

class ToClass
{
    public string[] Foo { get; set; }
}

这些类具有数组属性。它们可以是List<T>IEnumerable<T>,我在任何一种情况下都会得到相同的结果。

我尝试使用AutoMapper.QueryableExtensions

从一个映射到另一个
class Program
{
    static void Main(string[] args)
    {
        // create a "From" object
        string[] anArray = new string[] { "a", "b" };
        FromClass anObject = new FromClass() { Foo = anArray };

        // make a queryable set that includes the "From" object
        IQueryable<FromClass> queryableObjects = (new FromClass[] { anObject }).AsQueryable();

        // set up AutoMapper
        Mapper.CreateMap<FromClass, ToClass>();
        Mapper.AssertConfigurationIsValid();

        // test plain mapping
        IQueryable<ToClass> test1 = queryableObjects.Select(o => Mapper.Map<FromClass, ToClass>(o));
            // success!

        // test queryable extensions
        IQueryable<ToClass> test2 = queryableObjects.Project().To<ToClass>();
            // InvalidOperationException: "Sequence contains no elements"

    }
}

为什么test2会抛出InvalidOperationException?如果我将Foo的类型设置为不是集合的内容,例如一个string或其他类 - 然后一切都很完美。

我做错了吗?没理解什么?或者我遇到了一个错误?

1 个答案:

答案 0 :(得分:8)

我会说:这是一个错误:见Github Issue 159

AutoMapper.QueryableExtensions在内部使用Mapper.CreateMapExpression,所以如果你写:

var expression = Mapper.CreateMapExpression<FromClass, ToClass>();

它也会因同样的异常而失败。

似乎Mapper.CreateMapExpression目前不支持:

  • 值类型的通用集合,例如List<string>等。
  • 复杂类型或值类型的数组,例如string[]Bar[]等。

但如果你将Foo改为List<Item>,那么它可以正常工作:

public class FromClass
{
    public List<Item> Foo { get; set; }
}

public class ToClass
{
    public List<Item> Foo { get; set; }
}

public class Item
{
    public string Bar { get; set; }
}

var list =  new List<Item> { new Item{ Bar = "a"}, new Item() { Bar= "b" }};
FromClass anObject = new FromClass() { Foo = list };
var queryableObjects = (new FromClass[] { anObject }).AsQueryable();
Mapper.CreateMap<FromClass, ToClass>();
Mapper.CreateMap<Item, Item>();
var test2 = queryableObjects.Project().To<ToClass>().ToArray();

您可以对上述问题发表评论或使用您的代码创建一个新问题(这是对该错误的一个非常好的重复)