c# - 无法使用 SelectListitem 获取不同的值

标签 c# linq

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

有人可以告诉我如何使用正确的语法获取不同的值集吗?

IEnumerable<SelectListItem> ldidList = _db.TrafficHits.Select(c => new SelectListItem
            {
                Value = c.Id.ToString(),
                Text = c.ldid
            }).Distinct();

最佳答案

您当前代码的问题是 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;
        }
    }

然后你可以像这样使用它:-

IEnumerable<SelectListItem> ldidList = _db.TrafficHits.Select(c => new SelectListItem
            {
                Value = c.Id.ToString(),
                Text = c.ldid
            }).Distinct(new SelectListItemComparer());

关于c# - 无法使用 SelectListitem 获取不同的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29988659/

相关文章:

c# - 在 C# 中减小图像大小

c# - 跳过特定 Controller API 上的 [Authorize] 属性以获得可选授权是否安全?

c# - 检索数据 LINQ 与反射

c# - 在 LINQ 查询 'if' 语句中实现条件 'where' 语句

c# - linq-to-sql:SELECT 部分中的 GROUP BY 和 MIN()

c# - 从 XML、XSD 或 C# 类生成 LINQ DataContext

c# - C# 中有类似 Stackless Python 的东西吗?

c# - 启动期间在 Main-Method 中获取 WPF 应用程序中的键盘状态

c# - LINQ 查询中多列的总和

c# - 您如何在连接中包含第一个表中的所有字段,以及剩余的一些字段?