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 仍然只有 属性 名称对应于元组中的项目(Item1
、Item2
等),但使用 compiler/ide 魔法来使它们可以通过其他名称访问。所以 StyleId
或 StyleCode
不会是实际的 属性 名称,它们只是 Item1
和 Item2
的别名。
您要么必须等待团队添加对 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);
}
我需要 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 仍然只有 属性 名称对应于元组中的项目(Item1
、Item2
等),但使用 compiler/ide 魔法来使它们可以通过其他名称访问。所以 StyleId
或 StyleCode
不会是实际的 属性 名称,它们只是 Item1
和 Item2
的别名。
您要么必须等待团队添加对 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);
}