1

我正在使用 Simple.Data 及其 InMemoryAdapter 编写一些测试。下面的代码来自我的一项测试。测试应该返回 1 个值“Atlanta”,但是我得到了 Atlanta 两次。我想知道我是否错误地使用了 Distinct 的 InMemoryAdapter?

var adapter = new InMemoryAdapter();
Database.UseMockAdapter(adapter);

var db = Database.Open();
db.ParentRegionList.Insert(Id: 1, RegionName: "Dublin");
db.ParentRegionList.Insert(Id: 2, RegionName: "Atlanta");
db.ParentRegionList.Insert(Id: 3, RegionName: "Atlanta");
db.ParentRegionList.Insert(Id: 4, RegionName: "Killarney");
db.ParentRegionList.Insert(Id: 5, RegionName: "Bournemouth");

var result = db.ParentRegionList.All()
    .Where(db.ParentRegionList.RegionName.Like("At%"))
    .Distinct()
    .Select(db.ParentRegionList.RegionName).Take(10)
    .ToScalarList<string>();

我也试过:

var result = db.ParentRegionList.All()
    .Where(db.ParentRegionList.RegionName.Like("At%"))
    .Select(db.ParentRegionList.RegionName.Distinct()).Take(10)
    .ToScalarList<string>();
4

1 回答 1

0

我认为第二种格式是正确的,我有类似的问题。而不是使用强制转换作为
ToScalarList<string>()尝试创建一个虚拟类型,例如。"Region" 具有名称为 RegionName 的字符串属性并转换为:ToList<Region>()

于 2013-06-17T12:53:42.067 回答