Linq to sql 有什么办法可以实现消除列重复?
2016-03-23 10:19
330 查看
比如数据库里有一表,有两个字段:
ID User
1 小白
2 小红
3 小白
过滤User列为小白的重复项后,我想要得到:
ID User
1 小白
2 小红
如果写db.linq.customer.Distinct<customer>();这样只能是每行全部匹配过滤,请问我应该怎么做?
自定义比较运算符:
使用Linq中的Distinct方法对序列进行去重操作,讨论,LINQ去除重复的数据(某个字段有重复的数据),对linq查询结果进行去重处理。讨论,LINQ去除重复的数据(某个字段有重复的数据)的Distinct方法.
我写了下面一个类,然后在LINQ的查询语句后追加.Distinct(new MyComparer());
想实现查询的结果里,不存在姓名相同的行。
编译通过了,但使用它就报错说“不支持用于查询运算符“Distinct”的重载。”。
ID User
1 小白
2 小红
3 小白
过滤User列为小白的重复项后,我想要得到:
ID User
1 小白
2 小红
如果写db.linq.customer.Distinct<customer>();这样只能是每行全部匹配过滤,请问我应该怎么做?
自定义比较运算符:
//自定义比较符 public class MyComparer : IEqualityComparer<Customer> { public bool Equals(Customer x, Customer y) { return (x.User == y.User); } public int GetHashCode(User obj) { return obj.ToString().GetHashCode(); } } //消除重复数据 IEnumerable<Customer> CustomerDistinctList = db.Customers.ToList().Distinct(new MyComparer ());
使用Linq中的Distinct方法对序列进行去重操作,讨论,LINQ去除重复的数据(某个字段有重复的数据),对linq查询结果进行去重处理。讨论,LINQ去除重复的数据(某个字段有重复的数据)的Distinct方法.
我写了下面一个类,然后在LINQ的查询语句后追加.Distinct(new MyComparer());
想实现查询的结果里,不存在姓名相同的行。
编译通过了,但使用它就报错说“不支持用于查询运算符“Distinct”的重载。”。
相关文章推荐
- mongodb的c++接口说明
- SQL游标
- Aurora调用MySQL数据库的存储过程
- jedis,spring-redis-data 整合使用,版本问题异常以及解决。
- EF升级6.0数据库链接不上问题
- VS和psql在WIN7 64bit访问ORACLE
- Linux服务器安装Redis
- MySQL 查询语句(1)
- Redis学习笔记
- MySQL Replication(复制)基本原理
- DB2 SQLCODE 大全
- memcached总结
- 得到Mssql数据库表信息
- Redis开源代码读书笔记零(Ubuntu14.04 64位安装)
- mysql UNION ALL查询分页
- Ubuntu 14.04下MySQL服务器和客户端的安装
- DataGridView初始化——添加列、添加行号、连接数据库、单击单元格在文本框中显示
- sql 去除html标签函数
- 检测数据库日志的切换频率及归档文件大小的sql
- oracle 10g dataguard 测试