LINQ to Entities 不识别方法"System.String ToString()"

简介: 一、案例1,及解决方案: 在做批量删除时,需把一串id值所对应的数据删除,调试出现问题: Linq语句中如果使用ToString()进行类型转换,编译时不会报错,但执行时会出现如下错误: “LINQ to Entities 不识别方法"System.String ToString()",因此该方法无法转换为存储表达式。

一、案例1,及解决方案:

在做批量删除时,需把一串id值所对应的数据删除,调试出现问题:

Linq语句中如果使用ToString()进行类型转换,编译时不会报错,但执行时会出现如下错误:

LINQ to Entities 不识别方法"System.String ToString()",因此该方法无法转换为存储表达式。”

原因是Linq不支持ToString()函数。

可用下述方法进行转换解决:

string source = "1,2,3,4,5";

List<int> result = new List<string>(source.Split(',')).ConvertAll(i => int.Parse(i));

注: 需引用下列命名空间

using System.Collections.Generic;

using System.Linq;

 

二、案例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);
}
复制代码

 

相关资料:

http://archive.cnblogs.com/a/1878714/

http://stackoverflow.com/questions/1228318/linq-int-to-string

http://stackoverflow.com/questions/1066760/problem-with-converting-int-to-string-in-linq-to-entities

学习交流群:364976091
相关文章
|
8月前
|
编解码 Java 开发者
Java String类的关键方法总结
以上总结了Java `String` 类最常见和重要功能性方法。每种操作都对应着日常编程任务,并且理解每种操作如何影响及处理 `Strings` 对于任何使用 Java 的开发者来说都至关重要。
464 5
|
11月前
|
Java
介绍String.format()方法中的格式占位符用法。
通过综合使用它们,可以在Java中构造非常具体和高度定制的输出格式。这对于输出报道、创建用户界面或者任何需要精确控制输出格式的场合都非常有用。记住,当使用格式化方法时,需要确保提供的输入参数与占位符类型匹配,否则会抛出 java.util.IllegalFormatException。
1201 0
for循环和String类下方法的一个练习题
for循环和String类下方法的一个练习题
224 1
|
Java
【编程基础知识】(讲解+示例实战)方法参数的传递机制(值传递及地址传递)以及String类的对象的不可变性
本文深入探讨了Java中方法参数的传递机制,包括值传递和引用传递的区别,以及String类对象的不可变性。通过详细讲解和示例代码,帮助读者理解参数传递的内部原理,并掌握在实际编程中正确处理参数传递的方法。关键词:Java, 方法参数传递, 值传递, 引用传递, String不可变性。
383 1
【编程基础知识】(讲解+示例实战)方法参数的传递机制(值传递及地址传递)以及String类的对象的不可变性
|
JavaScript 算法 前端开发
JS算法必备之String常用操作方法
这篇文章详细介绍了JavaScript中字符串的基本操作,包括创建字符串、访问特定字符、字符串的拼接、位置查找、大小写转换、模式匹配、以及字符串的迭代和格式化等方法。
307 2
JS算法必备之String常用操作方法
|
XML Java API
List与String相互转化方法汇总
本文汇总了List与String相互转化的多种方法,包括使用`String.join()`、`StringBuilder`、Java 8的Stream API、Apache Commons Lang3的`StringUtils.join()`以及Guava的`Joiner.on()`方法实现List转String;同时介绍了使用`split()`方法、正则表达式、Apache Commons Lang3的`StringUtils.split()`及Guava的`Splitter.on()`方法实现String转List。
2743 1
List与String相互转化方法汇总
|
JavaScript 前端开发 API
javaScript中常用的String方法以及注意点总结
本文总结了JavaScript中常用的String对象的方法及其注意事项,包括大小写转换、字符获取、子字符串截取、字符串拼接、去除空格、替换、分割以及查找字符串中字符的索引等操作。提供了每种方法的使用示例代码,帮助理解它们的具体用法和差异。
312 2
|
JavaScript 前端开发 开发者
|
Java 索引
Java系列之 String indexOf() 方法
文章详细介绍了Java中`String`类的`indexOf()`方法的四种不同形式及其用法,包括查找字符和子字符串在字符串中的索引,并提供了相应的实例代码和输出结果。
|
Java 索引
java基础扫盲-String类常用的方法
java基础扫盲-String类常用的方法