一、案例1,及解决方案:
“LINQ to Entities 不识别方法"System.String ToString()",因此该方法无法转换为存储表达式。”
原因是LINQ to Entities 不支持ToString()函数。
可用下述方法进行转换解决:
DIRequest reqeust = new DIRequest();
reqeust.FilterMode = "1,2,3,4,5,6,7,8,9,0";
List<int> result = new List<string>(reqeust.FilterMode.Split(',')).ConvertAll(i => int.Parse(i));
return dal.T_Common_Dy.Where(m => result.Any(a => a == m.ParentItemID.Value)).ToList();
二、案例2,及解决方案:
//
获取市级地区
public
JsonResult GetCity(
string
id) { var city
=
from c
in
db.AreaDivide
where
c.ParentID
==
int
.Parse(id)
select
new
{ text
=
c.AreaName, value
=
c.ID };
return
Json(city.ToList(), JsonRequestBehavior.AllowGet); }
以上代码也会出现如下错误:
“LINQ to Entities 不识别方法"System.String ToString()",因此该方法无法转换为存储表达式。”
解决方案一:
//
获取市级地区
public
JsonResult GetCity(
string
id) {
int
a;
int
.TryParse(id,
out
a);
var city
=
from c
in
db.AreaDivide
where
c.ParentID
==
a
select
new
{ text
=
c.AreaName, value
=
c.ID };
return
Json(city.ToList(), JsonRequestBehavior.AllowGet); }
解决方案二:
using System.Data.Objects.SqlClient;
//在 System.Data.Entity.dll 中
//
获取市级地区
public
JsonResult GetCity(
string
id) { var city
=
from c
in
db.AreaDivide
where
SqlFunctions.StringConvert((
double
)c.ParentID)
==
id
select
new
{ text
=
c.AreaName, value
=
c.ID };
return
Json(city.ToList(), JsonRequestBehavior.AllowGet); }