我正在使用 LINQ to NHibernate 并在比较字符串时遇到了一个奇怪的问题。以下代码工作正常,但是当我取消注释时: //MyCompareFunc(dl.DamageNumber, damageNumberSearch) && 和评论:dl.DamageNumber.Contains(damageNumberSearch) && 然后它崩溃了,似乎 MyCompareFunc() 在 dl 时总是返回 true。 DamageNumber.Contains(damageNumberSearch) 有时返回 true,有时返回 false。
换句话说,当我在 LINQ 查询中直接使用 string.Contains() 时,它可以工作,但是当我将它移到一个方法时,它就不起作用了。
internal List<DamageList> SearchDamageList(
DateTime? sendDateFromSearch, DateTime? sendDateToSearch, string damageNumberSearch,
string insuranceContractSearch)
{
var q = from dl in session.Linq<DamageList>()
where
CommonHelper.IsDateBetween(dl.SendDate, sendDateFromSearch, sendDateToSearch) &&
//MyCompareFunc(dl.DamageNumber, damageNumberSearch) &&
dl.DamageNumber.Contains(damageNumberSearch) &&
insuranceContractSearch == null ? true : CommonHelper.IsSame(dl.InsuranceContract, insuranceContractSearch)
select dl;
return q.ToList<DamageList>();
}
private bool MyCompareFunc(string damageNumber, string damageNumberSearch)
{
return damageNumber.Contains(damageNumberSearch);
}