试图执行linq查询时出现以下错误: LINQ to Entities不识别方法'布尔IsCharityMatching(System.String,System.String)'方法,并且此方法不能被转换为存储expression式。 我读过很多以前的问题,人们得到相同的错误,如果我正确地理解这是因为LINQ to Entities要求整个LINQ查询expression式被转换为服务器查询,因此你不能调用一个外部方法在里面。 我还没有能够把我的情景转化成现在可行的东西,我的大脑开始融化,所以我希望有人能够指引我正确的方向。 我们正在使用entity framework和规范模式(我是新来的)。 以下是使用规范的代码: ISpecification<Charity> specification = new CharitySearchSpecification(charityTitle, charityReference); charities = charitiesRepository.Find(specification).OrderBy(p => p.RegisteredName).ToList(); 这里是linqexpression式: public System.Linq.Expressions.Expression<Func<Charity, bool>> IsSatisfied() { return p => p.IsCharityMatching(this.charityName, this.charityReference); } 这是IsCharityMatching方法: public bool IsCharityMatching(string name, string referenceNumber) { bool exists = true; if (!String.IsNullOrEmpty(name)) { if (!this.registeredName.ToLower().Contains(name.ToLower()) && !this.alias.ToLower().Contains(name.ToLower()) && !this.charityId.ToLower().Contains(name.ToLower())) […]