我需要使用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
。我错过了什么?
坦率地说,它不支持元组的工作方式。 Dapper的反序列化器使用构造函数参数或属性/字段在对象的类型中按名称映射列值。 ( 来源如果你能理解生成的IL)。
另一方面,ValueTuples仍然只具有与元组( Item1
, Item2
等)中的项对应的属性名称,但使用编译器/ ide魔术使其可以通过其他名称访问。所以StyleId
或StyleCode
不是实际的属性名,它们只是Item1
和Item2
别名。
您要么必须等待团队添加对ValueTuples的显式支持,要么在查询中使用预期的属性名称。
var query = $@" SELECT
ST.style_id as Item1, ST.style_code as Item2
...
...";
好像他们是几个月前添加的。这是测试中的示例用法:
[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);
}