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

一、举例

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  LandCover=@type group by Precision, Year, LandCover", new SqlParameter("@type", "森林")).Select(d=> d.Area).ToList();

//2)增删改:ExecuteSqlCommand

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

 
解决问题的一般流程总结:
1自己想
2百度
3官网文档
4问大神
 

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

  1. C# MVC EF中匿名类使用

    控制器中代码: var list = context.Says.Join( context.Users, a => a.UserId, b => b.Id, (a, b) => ne ...

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

    在开发中可能会遇到这几种情况 1.EF或LINQ查询出来的匿名对象在其它地方调用不方便,又懒的手动建实体类 2.通过datatable反射实体需要先建一个类 ,头痛 3.通过SQL语句返回的实体也需要 ...

  3. 读取ViewBag匿名类

    关于遍历 viewBag匿名类错误 EF tt生成的类 明明有值眼睁睁看着 却不认识 public ActionResult Index() { MyTestEntities1 db = new My ...

  4. MVC匿名类传值学习

    刚接触MVC+EF框架不久,但一直很困惑的就是控制器能否及如何向视图传递匿名类数据.宝宝表示很讨厌去新建实体类啦,查询稍有不同就去建一个实体类不是很麻烦吗,故趁阳光正好,周末睡到自然醒后起来尝试了之前 ...

  5. HttpCookie加匿名类实现多语言

    突然想做一个多语言网站,确不知道怎么实现好,突然想到了HttpCookie,然后页面后台用匿名类实现语言的储存. string lan = Request["str_lan"]; ...

  6. Linq之隐式类型、自动属性、初始化器、匿名类

    目录 写在前面 系列文章 隐式类型 自动属性 初始化器 匿名类 总结 写在前面 上篇文章是本系列的小插曲,也是在项目中遇到,觉得有必要总结一下,就顺手写在了博客中,也希望能帮到一些朋友.本文将继续介绍 ...

  7. .net学习之新语法学习(匿名类和匿名方法,扩展方法,系统内置委托,Lambda表达式和linq等)

    1.自动属性 Auto-Implemented Properties 2.隐式类型 var  var变量不能作为全局变量使用,因为不能在编译时确定类型 3.参数默认值 和 命名参数 4.对象初始化器 ...

  8. silverlight datagrid绑定匿名类

    原文 http://www.cnblogs.com/luweis/archive/2011/10/21/2220587.html 刚开始遇到的一个问题是这样的,我有一个datagrid,根据不同的条件 ...

  9. C# 3.0 / C# 3.5 对象集合初始化器、匿名类

    对象集合初始化器 在 .NET 2.0 中构造一个对象的方法一是提供一个重载的构造函数,二是用默认的构造函数生成一个对象,然后对其属性进行赋值. 在 .NET 3.5/C# 3.0 中,我们有一种更好 ...

随机推荐

  1. GitHub--创建新的分支(转)

    如何在 GitHub 的项目中创建一个分支呢? 其实很简单啦,直接点击 Branch,然后在弹出的文本框中添加自己的 Branch Name 然后点击蓝色的Create branch就可以了,这样一来 ...

  2. 2017-2018-1 20155326信息安全系统设计基础》嵌入式C语言课上考试补交

    2017-2018-1 20155326信息安全系统设计基础>嵌入式C语言课上考试补交 PPT上的例子 已知位运算规则为: &0 --> 清零 &1 --> 不变 | ...

  3. 2.DI依赖注入

    一:DI Dependency Injection ,依赖注入 is a :是一个,继承. has a:有一个,成员变量,依赖. class B { private A a;   //B类依赖A类 } ...

  4. 去除swagger ui的红色 error 错误提示

    去除swagger ui的红色 error 错误提示 自定义js文件中加入以下的代码. 加入自定义的js方法看这里 http://www.cnblogs.com/wang2650/archive/20 ...

  5. [UWP]在UWP平台中使用Lottie动画

    最近QQ影音久违的更新了,因为记得QQ影音之前体验还算不错(FFmepg的事另说),我也第一时间去官网下载体验了一下,结果发现一些有趣的事情. 是的,你没看错,QQ影音主界面上这个动画效果是使用Lot ...

  6. 关于 redis的操作

    1.修改配置文件 redis.conf是redis的配置文件,redis.conf在redis源码目录. 注意修改port作为redis进程的端口,port默认6379.如果需要搭建redis集群,千 ...

  7. centos7上安装cacti监控

     简介 在企业网络运维过程中,管理员必须时刻关注服务器的运行状态,如CPU.内存.磁盘空间使用情况等.为了能够及时的发现问题,尽量减少故障的发生.当网络中的设备,服务器等数量较多时,可以部署一套监控系 ...

  8. spring boot 访问静态资源的步骤

    1)resources/static下放置html文件.(或者static下新建目录 http://hcss:8090/imgs/单例.png) 2)webapp下放置html文件. 如果两个路径下有 ...

  9. nRF52832 矩阵按键调试 同一列上的按键 任意两个按键 按下 检测不到低电平(电平拉不下来)

    参考链接:https://blog.csdn.net/zhanghuaishu0/article/details/78505045 调试过程中发现 同一列上的按键 任意两个按键 按下 检测不到低电平( ...

  10. servlet(二)

    http协议 (1)什么是http协议? 是一种网络应用层协议,规定了浏览器如何与web服务器之间进行通信以及相应的 数据包的结构. 浏览器与web服务器之间如何通信? step1.建立连接 step ...