我需要使用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
。
我错过了什么?
答案 0 :(得分:11)
坦率地说,它不支持元组的工作方式。 Dapper的反序列化器使用构造函数参数或属性/字段按对象类型的名称映射列值。 (Source如果你能理解生成的IL)。
另一方面,ValueTuples仍然只具有与元组(Item1
,Item2
等中的项对应的属性名称),但使用编译器/ ide魔术使其可以通过其他名称访问。因此StyleId
或StyleCode
不是实际的属性名称,它们只是Item1
和Item2
的别名。
您必须等待团队添加对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);
}