Dapper实现了一个元组

时间:2017-01-12 16:10:56

标签: c# tuples dapper c#-7.0

我需要使用C#7中的新元组从dapper返回一个列表。

public static List<(int StyleId, decimal StyleCode)> GetOnlyServices()
{
    var query = $@" SELECT
                    ST.style_id as StyleId, ST.style_code as StyleCode
                    ...
                    ...";

    using (SqlConnection db = new SqlConnection(InfobaseConString))
    {
        var a = db.Query<(int StyleId, decimal StyleCode)>(query, commandTimeout: 90).ToList();
        return a;
    }
}

但是这个函数只返回56行(0,0), Item1=0, Item2=0。 我错过了什么?

2 个答案:

答案 0 :(得分:11)

坦率地说,它不支持元组的工作方式。 Dapper的反序列化器使用构造函数参数或属性/字段按对象类型的名称映射列值。 (Source如果你能理解生成的IL)。

另一方面,ValueTuples仍然只具有与元组(Item1Item2等中的项对应的属性名称),但使用编译器/ ide魔术使其可以通过其他名称访问。因此StyleIdStyleCode不是实际的属性名称,它们只是Item1Item2的别名。

您必须等待团队添加对ValueTuples的显式支持或在查询中使用预期的属性名称。

var query = $@" SELECT
                ST.style_id as Item1, ST.style_code as Item2
                ...
                ...";

答案 1 :(得分:1)

好像他们是几个月前添加的。这是tests中的用法示例:

[Fact] public void TupleReturnValue_Works_NamesIgnored() { var val = connection.QuerySingle<(int id, string name)>("select 42 as [Item2], 'Fred' as [Item1]"); Assert.Equal(42, val.id); Assert.Equal("Fred", val.name); }