模型定义的功能无法识别

时间:2015-06-04 21:42:07

标签: c# asp.net asp.net-mvc linq linq-to-entities

我有一个带有.edmx文件的ASP.NET 4.0 MVC项目,使用Linq to Entities。我在概念模型中添加了一个函数,我得到了不支持"错误。

EF版本:

<package id="EntityFramework" version="6.1.3" targetFramework="net40" />

这是edmx部分:

<edmx:ConceptualModels>
  <Schema Namespace="MillCertsModel" Alias="Self" xmlns="http://schemas.microsoft.com/ado/2009/11/edm" annotation:UseStrongSpatialTypes="false" xmlns:annotation="http://schemas.microsoft.com/ado/2009/02/edm/annotation">
  ... EntityType elements ...
  <Function Name="IsLike" ReturnType="Edm.Boolean">
      <Parameter Name="str" Type="Edm.String" />
      <Parameter Name="pattern" Type="Edm.String" />
      <DefiningExpression>
        str LIKE pattern
      </DefiningExpression>
    </Function>
  </Schema>
</edmx:ConceptualModels>

和功能......

public static class Utilities
{
    [System.Data.Objects.DataClasses.EdmFunction("MillCertsModel", "IsLike")]
    public static bool IsLike(this string str, string pattern)
    {
        throw new NotSupportedException("Supported for SQL queries only.");
    }
}

和代码......

if (keywords != null)
   query = query.Where(m => keywords.Any(kw => m.CertificateData.Any(cd => cd.value.ToLower() == kw || cd.value.IsLike("[^a-z]"))));

错误:LINQ to Entities无法识别方法&#39;布尔IsLike(System.String,System.String)&#39;方法,此方法无法转换为商店表达式。

1 个答案:

答案 0 :(得分:1)

发现了这个问题。命名空间错了。

更正名称空间:

System.Data.Entity.Core.Objects.DataClasses

// NOT: System.Data.Objects.DataClasses.EdmFunction

但是,此属性现已过时。建议使用System.Data.Entity.DbFunctionAttribute