无法使用SelectListitem获取不同的值

sag*_*y36 7 c# linq

我正在尝试为下拉列表获取不同的值,但是当使用以下语法时,它会将所有行返回给我.

有人可以通知我如何使用正确的语法获得不同的值集?

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)


Bil*_*adi 6

您可以使用分组依据,然后选择每个分组的第一个元素:

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)