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
相关文章
|
4月前
for循环和String类下方法的一个练习题
for循环和String类下方法的一个练习题
58 1
|
2月前
|
Java
【编程基础知识】(讲解+示例实战)方法参数的传递机制(值传递及地址传递)以及String类的对象的不可变性
本文深入探讨了Java中方法参数的传递机制,包括值传递和引用传递的区别,以及String类对象的不可变性。通过详细讲解和示例代码,帮助读者理解参数传递的内部原理,并掌握在实际编程中正确处理参数传递的方法。关键词:Java, 方法参数传递, 值传递, 引用传递, String不可变性。
67 1
【编程基础知识】(讲解+示例实战)方法参数的传递机制(值传递及地址传递)以及String类的对象的不可变性
|
1月前
|
JavaScript 前端开发 开发者
|
3月前
|
JavaScript 前端开发 API
javaScript中常用的String方法以及注意点总结
本文总结了JavaScript中常用的String对象的方法及其注意事项,包括大小写转换、字符获取、子字符串截取、字符串拼接、去除空格、替换、分割以及查找字符串中字符的索引等操作。提供了每种方法的使用示例代码,帮助理解它们的具体用法和差异。
44 2
|
4月前
|
JavaScript 算法 前端开发
JS算法必备之String常用操作方法
这篇文章详细介绍了JavaScript中字符串的基本操作,包括创建字符串、访问特定字符、字符串的拼接、位置查找、大小写转换、模式匹配、以及字符串的迭代和格式化等方法。
JS算法必备之String常用操作方法
|
4月前
|
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。
148 1
List与String相互转化方法汇总
|
4月前
|
Java API 索引
【Java基础面试二十四】、String类有哪些方法?
这篇文章列举了Java中String类的常用方法,如`charAt()`、`substring()`、`split()`、`trim()`、`indexOf()`、`lastIndexOf()`、`startsWith()`、`endsWith()`、`toUpperCase()`、`toLowerCase()`、`replaceFirst()`和`replaceAll()`,并建议面试时展示对这些方法的熟悉度,同时深入理解部分方法的源码实现。
【Java基础面试二十四】、String类有哪些方法?
|
3月前
|
Java 索引
java基础扫盲-String类常用的方法
java基础扫盲-String类常用的方法
|
4月前
|
Java 索引
Java系列之 String indexOf() 方法
文章详细介绍了Java中`String`类的`indexOf()`方法的四种不同形式及其用法,包括查找字符和子字符串在字符串中的索引,并提供了相应的实例代码和输出结果。
|
4月前
|
Dragonfly Dart NoSQL
Dart ffi 使用问题之在Dart中调用String的toNativeUtf8方法时有什么是需要注意的
Dart ffi 使用问题之在Dart中调用String的toNativeUtf8方法时有什么是需要注意的