我正在尝试为下拉列表获取不同的值,但是当使用以下语法时,它会将所有行返回给我.
有人可以通知我如何使用正确的语法获得不同的值集?
IEnumerable<SelectListItem> ldidList = _db.TrafficHits.Select(c => new SelectListItem
{
Value = c.Id.ToString(),
Text = c.ldid
}).Distinct();
Run Code Online (Sandbox Code Playgroud)
Rah*_*ngh 10
您当前代码的问题是Distinct将使用默认比较器SelectListItem.您需要提供这样的自定义比较器: -
public class SelectListItemComparer : IEqualityComparer<SelectListItem>
{
public bool Equals(SelectListItem x, SelectListItem y)
{
return x.Text == y.Text && x.Value == y.Value;
}
public int GetHashCode(SelectListItem item)
{
int hashText = item.Text == null ? 0 : item.Text.GetHashCode();
int hashValue = item.Value == null ? 0 : item.Value.GetHashCode();
return hashText ^ hashValue;
}
}
Run Code Online (Sandbox Code Playgroud)
然后你就可以这样使用它: -
IEnumerable<SelectListItem> ldidList = _db.TrafficHits.Select(c => new SelectListItem
{
Value = c.Id.ToString(),
Text = c.ldid
}).Distinct(new SelectListItemComparer());
Run Code Online (Sandbox Code Playgroud)
您可以使用分组依据,然后选择每个分组的第一个元素:
IEnumerable<SelectListItem> ldidList = _db.TrafficHits
.GroupBy(t => t.Id)
.Select(g => g.First())
.Select(c => new SelectListItem
{
Value = c.Id.ToString(),
Text = c.ldid
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3942 次 |
| 最近记录: |