Dapper具体化为元组

Dapper materializing to a Tuple

我需要 return 来自 dapper 的列表以及 C# 7 中的新元组。

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;
    }
}

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

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

另一方面,

ValueTuples 仍然只有 属性 名称对应于元组中的项目(Item1Item2 等),但使用 compiler/ide 魔法来使它们可以通过其他名称访问。所以 StyleIdStyleCode 不会是实际的 属性 名称,它们只是 Item1Item2 的别名。

您要么必须等待团队添加对 ValueTuples 的明确支持,要么在查询中使用预期的 属性 名称。

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

看起来他们是几个月前添加的。这是 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);
    }