架构师_程序员

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 168|回复: 2

[交流] EF 汇总函数使用注意事项Max()/Min()等

[复制链接]
跳转到指定楼层
楼主
发表于 2019-4-15 16:52:06

一、字符串类型最大值

1.字符串类型的最大值,和数据库的字典排序最后一个相同,如果存在返回null

  1. //字符串最大值,是字典排序最后一个
  2. string max1 = _context.students.Max(q => q.sname);
  3. Console.WriteLine(max1);

  4. //字符串最大值,如果不存在返回null
  5. string max2 = _context.students
  6.     .Where(q => false)
  7.     .Max(q => q.sname);
  8. Console.WriteLine(max2);
  9. Console.WriteLine(max2 == null); //True
  10. Console.WriteLine(max2 == ""); //False   
复制代码

二、数字类型最大值

1.数字类型最大值,和数据库字段排序最后一个相同,如果没有数据抛出异常。

  1. //数字类型,获取最大值为正序排列最后一个值
  2.             decimal deci1 = _context.scores.Max(q => q.degree);
  3.             Console.WriteLine(deci1);
复制代码

数字类型,获取条件的数据不存在抛出异常
其他信息: 到值类型“System.Decimal”的强制转换失败,因为具体化值为 null。
结果类型的泛型参数或查询必须使用可以为 null 的类型。

  1. decimal deci2 = _context.scores.Where(q => false).Max(q => q.degree);
  2.             Console.WriteLine(deci2);
复制代码

解决方案1(推荐):

  1. //解决方案1,使用DefaultIfEmpty(),推荐
  2. var query = _context.scores.Where(q => false)
  3.     .Select(q => q.degree)
  4.     .DefaultIfEmpty();
  5. Console.WriteLine(query.ToString());
  6. decimal deci3 = query
  7.     .Max();
  8. Console.WriteLine(deci3);

复制代码

生成sql如下:

解决方案2:

  1. //解决方案2,先判断再取值,<font color="#ff0000">执行两次数据库查询</font>
  2. decimal deci4 = 0;
  3. if (_context.scores.Any())
  4. {
  5.     deci4 = _context.scores.Max(q => q.degree);
  6. }
  7. Console.WriteLine(deci4);

复制代码

解决方案3:

  1. //解决方案3,内存取最大值
  2. decimal deci5 = _context.scores
  3.     .Select(q => q.degree)
  4.     .ToList()
  5.     .Max();
复制代码







上一篇:百万年薪聘:数据算法工程师(懂高性能计算加速架构、...
下一篇:PowerDesigner16.5汉化破解版安装教程(含安装文件、汉化包、...
帖子永久地址: 

架构师_程序员 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
2、本站所有主题由该帖子作者发表,该帖子作者与架构师_程序员享有帖子相关版权
3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和架构师_程序员的同意
4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
7、架构师_程序员管理员和版主有权不事先通知发贴者而删除本文

码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
沙发
 楼主| 发表于 2019-4-15 16:55:03
linq sum source为空的两种处理方式
https://www.itsvse.com/thread-4561-1-1.html
(出处: 架构师_程序员)
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
板凳
 楼主| 发表于 2019-4-15 16:55:15
到值类型“System.Decimal”的强制转换失败...
https://www.itsvse.com/thread-7223-1-1.html
(出处: 架构师_程序员)
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。

Mail To:help@itsvse.com

QQ|Archiver|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2019-6-17 13:14

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表