EF select 匿名类 问题

连续两次被相同问题困扰。

一、举例

var query=db.StudentScore.Where(r=> r.SubjectId==subjectId).Select(g=>new {SubjectId=SubjectId,Score=g.Score}).ToList();

这是一段平常的代码,但有时候他会报错:匿名类无法转换为实体类StudentScore。

1期初,我是这么想的:

new StudentScore

var query=db.StudentScore.Where(r=> r.SubjectId==subjectId).Select(g=>new StudentScore {SubjectId=SubjectId,Score=g.Score}).ToList();

但还是报错!原因还是匿名类无法转换为实体类StudentScore。

问:为什么不能转换为自己呢?答: 难道因为实体类中有外键或者字段数量上不匹配吗。。

2 新建了一个类

StudentScoreTemp   就两个属性 SubjectId、 Score

var query=db.StudentScore.Where(r=> r.SubjectId==subjectId).Select(g=>new StudentScoreTemp   {SubjectId=SubjectId,Score=g.Score}).ToList();

转换成功。

3后来发现CSDN 已经有答案 https://bbs.csdn.net/topics/390777388

其中还记录了另一种方法:query就是个集合,你遍历就行了

foreach(var v in query)  遍历的时候按自己需要重新组装成需要的形式。

 

4还发现了一个错误的方法:

var query=db.StudentScore.Where(r=> r.SubjectId==subjectId).AsEnumerable().Select(new StudentScoreTemp() { ... }).ToList()

错误原因:

AsEnumerable() 时会去数据库查询数据,相当于把数据先查询出来到内存中,再在内存中通过Select筛选。如果数据量较大是非常消耗内存的!

原因详情见 :https://www.cnblogs.com/joeatgz/p/5180788.html

5 新发现

var query=db.StudentScore.Where(r=> r.SubjectId==subjectId).Select(g=>g).ToList();

这样可以查询所有字段

6 还发现  Select的时候,时间无法转换成 年月日  YYMMMdd

解决1:先ToList到内存,然后再次Select时可以转换。

解决2:  先匿名类接收数据, foreach循环或for 循环遍历的时候按自己需要重新组装成需要的形式。(3中的发现是有用滴!)

7 又发现EF复杂查询好难呀!

这是对EF拉姆达表达式和linq语法不熟悉是很费时间的,其实可以

1直接在数据库中创建视图。

2EF也可以直接写sql语句

  //1)查询SqlQuery

  result.slList = db.Database.SqlQuery<DataTemp>("select Precision,Year,LandCover, sum(Area) as Area  from [EcoTypes]  where  [email protected] group by Precision, Year, LandCover", new SqlParameter("@type", "森林")).Select(d=> d.Area).ToList();

//2)增删改:ExecuteSqlCommand

db.Database.ExecuteSqlCommand("").ToString();

解决问题的一般流程总结:

1自己想

2百度

3官网文档

4问大神

原文地址:https://www.cnblogs.com/hao-1234-1234/p/9112434.html

时间: 2024-10-15 03:17:14

EF select 匿名类 问题的相关文章

MVC匿名类传值学习

刚接触MVC+EF框架不久,但一直很困惑的就是控制器能否及如何向视图传递匿名类数据.宝宝表示很讨厌去新建实体类啦,查询稍有不同就去建一个实体类不是很麻烦吗,故趁阳光正好,周末睡到自然醒后起来尝试了之前一直在博客园看到的实现方式:英明神武的Tuple类,第一次对微软钦佩之至.故做如下记录,方便自己之后使用.大神就勿喷我啦,宝宝第一次写博客. 首先先描述一下我要实现的功能:从控制器后台查询一些数据,通过匿名类存储,在视图前端遍历输出.初衷实现流程如下: 控制器部分: 1 2 3 4 5 6 7 8

读取ViewBag匿名类

关于遍历 viewBag匿名类错误 EF tt生成的类 明明有值眼睁睁看着 却不认识 1 public ActionResult Index() 2 { 3 4 MyTestEntities1 db = new MyTestEntities1(); 5 6 var source = from c in db.Student select new { c.DocId, c.StuAge, c.StuName }; 7 ViewBag.source = source; 8 return View()

.net 根据匿名类生成实体类,根据datatable生成实体类,根据sql生成实体类

在开发中可能会遇到这几种情况 1.EF或LINQ查询出来的匿名对象在其它地方调用不方便,又懒的手动建实体类 2.通过datatable反射实体需要先建一个类 ,头痛 3.通过SQL语句返回的实体也需要先建一个类 ,头痛 4.如果通过代码生成器要写模版,需要安装或者不想生成一堆不用的类 为了解决上面的不便之处,我封装了一个实体生成类,可以扔到程序里面任意调用 封装类: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25

HttpCookie加匿名类实现多语言

突然想做一个多语言网站,确不知道怎么实现好,突然想到了HttpCookie,然后页面后台用匿名类实现语言的储存. string lan = Request["str_lan"]; ViewBag.lan = lan; HttpCookie hc = new HttpCookie("language"); hc.Value = lan; hc.Expires = DateTime.Now.AddDays(1); Response.Cookies.Add(hc); Ht

内部类与匿名类(转)

Java 中的内部类和匿名类* 为什么需要内部类? Java 内部类有什么好处?为什么需要内部类? 首先举一个简单的例子,如果你想实现一个接口,但是这个接口中的一个方法和你构想的这个类中的一个方法的名称,参数相同,你应该怎么办?这时候,你可以建一个内部类实现这个接口.由于内部类对外部类的所有内容都是可访问的,所以这样做可以完成所有你直接实现这个接口的功能. 不过你可能要质疑,更改一下方法的不就行了吗? 的确,以此作为设计内部类的理由,实在没有说服力.真正的原因是这样的,java 中的内部类和接口

Java中的内部类、匿名类的使用

代码(test.java): 1 interface ie{ 2 public void print(); 3 } 4 5 class outer{} 6 7 public class test{ 8 public class inner{} 9 public void test(ie e){ 10 e.print(); 11 } 12 public static void main(String[] args){ 13 14 15 new test().test(new ie(){ 16 pu

解决内存泄漏更加清楚的认识到Java匿名类与外部类的关系

1.事件起因 在做项目的时候,通过Android Studio的Memory Monitor窗口观察程序内存使用情况,发现当程序退出的时候,有一部分应该释放掉的内存没有释放掉,知道程序中应该有内存泄漏了.为了发现程序中的内存泄漏,我切换了IDE工具到Eclipse,里面安装了内存泄漏的分析工具MAT,具体怎么用MAT分析内存泄漏可以自己Google,我把我自己找到内存泄漏的地方贴出来 从上图中可以看到,有24M左右的内存被mView(其实它真正是一个Fragment)这个变量持有,导致Java垃

Java匿名类

public class Person { public void hello() { System.out.println("我是Person"); } } 1 public class Main 2 { 3 /** 4 * 主函数,程序的入口 5 * @param args 6 */ 7 public static void main(String[] args) 8 { 9 final int num=90;//局部变量 10 11 //匿名类 12 Person p1=new

JAVA学习--匿名类的使用

1 public class TestProduct { 2 public static void main(String[] args) { 3 TestProduct t = new TestProduct(); 4 //方式一:创建一个实现Product接口的类的对象,并将此对象传入方法中 5 NoteBook n = new NoteBook(); 6 t.show(n); 7 //方式二:创建一个实现Product接口的匿名类的对象 8 Product p = new Product(