我正面临着IEquatable (C#)的问题。正如您在下面的代码中所看到的,我得到了一个实现IEquatable的类,但是它的“相等”方法无法到达。我的目标是:我的数据库中有一个datetime列,我只想区分日期,而不是考虑“时间”部分。
例如: 12-01-2014 23:14等于12-01-2014 18:00。
namespace MyNamespace
{
public class MyRepository
{
public void MyMethod(int id)
{
var x = (from t in context.MyTable
where t.id == id
select new MyClassDatetime()
{
Dates = v.Date
}).Distinct().ToList();
}
}
public class MyClassDatetime : IEquatable<MyClassDatetime>
{
public DateTime? Dates { get; set; }
public bool Equals(MyClassDatetime other)
{
if (other == null) return false;
return (this.Dates.HasValue ? this.Dates.Value.ToShortDateString().Equals(other.Dates.Value.ToShortDateString()) : false);
}
public override bool Equals(object other)
{
return this.Equals(other as MyClassDatetime );
}
public override int GetHashCode()
{
int hashDate = Dates.GetHashCode();
return hashDate;
}
}
}你知道我怎样才能使它正常工作或做我所需要的其他选择吗?谢谢你!!
发布于 2014-07-10 18:03:24
这是我的回答,但它仍然不能解决我的问题。
我终于找到了一种方法,但不用使用IEquatable。
var x=(在EntityFunctions.CreateDateTime(t.Date.Value.Year,context.MyTable中,t.Id == id选择t.Date.Value.Month,t.Date.Value.Day,0,0,0).Distinct();
=)
发布于 2014-07-08 14:44:13
对于所需的平等语义,GetHashCode的实现是不正确的。这是因为它为您想要比较相等的日期返回不同的散列代码,which is a bug。
若要修复它,请将其更改为
public override int GetHashCode()
{
return Dates.HasValue ? Dates.Value.Date.GetHashCode() : 0;
}您还应该本着同样的精神更新Equals,处理日期的字符串表示不是一个好主意:
public bool Equals(MyClassDatetime other)
{
if (other == null) return false;
if (Dates == null) return other.Dates == null;
return Dates.Value.Date == other.Dates.Value.Date;
}更新:作为usr very correctly points out,因为您在IQueryable上使用LINQ,投影和Distinct调用将被转换为存储表达式,而这段代码仍然不会运行。要解决这个问题,您可以使用中间AsEnumerable调用:
var x = (from t in context.MyTable
where t.id == id
select new MyClassDatetime()
{
Dates = v.Date
}).AsEnumerable().Distinct().ToList();https://stackoverflow.com/questions/24634747
复制相似问题