Linq 中 Any与All

昨天突然看到之前写的一个积累文档,其中文档中有一个Linq Any和All的注意事项:

注意Any All

            var list = new List<int>();

            var aa = list.All(n => n > 1);

            var bb = list.Any(n => n > 1);

            // aa: true       bb: false

 

其中List是一个元素个数为0的整型List。
可能大多数人跟我一样,第一次见到都会认为aa为false。
然后这个是我在程序中写Linq的时候,造成了很大困惑,明明条件是正确的(当时一直认为aa为false),却结果不对。 
最后一句一句,一个条件一个条件的拆分了执行,才找到这个原因。
看看他生成的SQL,我们就知道原因了

All:      IQueryable<Test>.All(t=>t.OpenId=="")

 1 -- Region Parameters
 2 DECLARE @p0 NVarChar(1000= ''
 3 -- EndRegion
 4 SELECT 
 5     (CASE 
 6         WHEN NOT (EXISTS(
 7             SELECT NULL AS [EMPTY]
 8             FROM [Test] AS [t1]
 9             WHERE (
10                 (CASE 
11                     WHEN [t1].[OpenId] = @p0 THEN 1
12                     ELSE 0
13                  END)) = 0
14             )) THEN 1
15         WHEN NOT NOT (EXISTS(
16             SELECT NULL AS [EMPTY]
17             FROM [Test] AS [t1]
18             WHERE (
19                 (CASE 
20                     WHEN [t1].[OpenId] = @p0 THEN 1
21                     ELSE 0
22                  END)) = 0
23             )) THEN 0
24         ELSE NULL
25      ENDAS [value]

 可以看得出来, All 是用的 Not (Exists) , 当Query为空的时候,Exists是为false的,而前面一个Not (false),当然也成为了True;

 Any:          IQueryable<Test>.Any(t=>t.OpenId=="")

  1 -- Region Parameters

 2 DECLARE @p0 NVarChar(1000= ''
 3 -- EndRegion
 4 SELECT 
 5     (CASE 
 6         WHEN EXISTS(
 7             SELECT NULL AS [EMPTY]
 8             FROM [Test] AS [t0]
 9             WHERE [t0].[OpenId] = @p0
10             ) THEN 1
11         ELSE 0
12      ENDAS [value]

 

可以看出   Any生成的是Exists。  当Query为空的时候,Exists是为false的。

 

转载于:https://www.cnblogs.com/AaronAndJoe/p/4642231.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/258608.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

jaxb转xml空值双标签_单品运营思维:标签-词路-聚焦-直搜-超直

非标品标签思维&#xff1a;针对非标品 主要是2.0为主的打法根据搜索入池的关键词&#xff0c;有什么词做什么词。有个细节&#xff1a;不一定进什么词做什么词&#xff0c;这个维度当中加入3.0的思维3.0入手 转2.0再切3.0(检测词路健康度&#xff0c;非严格意义估算单量)举例&…

如何在PFSense中设置故障转移和负载平衡

故障转移是一种备份操作模式&#xff0c;仅在主系统由于系统故障或任何计划停机时间而变得不可用时&#xff0c;系统组件&#xff08;如网络&#xff09;的操作才由辅助系统承担。在本教程中&#xff0c;我们将看到如何设置故障转移和负载平衡&#xff0c;以使pfSense能够将流量…

图像金字塔总结

本文转载自&#xff1a; http://blog.csdn.net/dcrmg/article/details/52561656 一、 图像金字塔 图像金字塔是一种以多分辨率来解释图像的结构&#xff0c;通过对原始图像进行多尺度像素采样的方式&#xff0c;生成N个不同分辨率的图像。把具有最高级别分辨率的图像放在底部…

表单的get和post使用情景

GET和POST两种方法都是将数据送到服务器&#xff0c;但你该用哪一种呢&#xff1f;HTTP标准包含这两种方法是为了达到不同的目的。POST用于创建资源&#xff0c;资源的内容会被编入HTTP请示的内容中。例如&#xff0c;处理订货表单、在数据库中加入新数据行等。 当请求无副作用…

什么叫做罗列式_项目起盘的时候,如何确定自己该做什么社群?

这是祁杰『社群日记』第48篇持续日更&#xff0c;做最懂社群的营销咨询人很多人手上有资源&#xff0c;准备起盘项目的时候&#xff0c;总会思考一个问题&#xff1a;我能做什么样的社群&#xff1f;今天我们从用户需求出发&#xff0c;拆解一下哪些社群是能够确切地满足用户的…

C++ exit 与 return 浅析

【摘要】 本文从代码形式。经常使用方式&#xff0c;相关概念&#xff0c;调用关系和比較分析&#xff0c;这5个维度浅析 exit 与 return 在C的同样点与差别。【常见形式】 exit(0)&#xff1a; 正常执行程序并退出程序。 exit(1)&#xff1a; 非正常执行导致退出程序&…

Feature Pyramid Networks for Object Detection 总结

最近在阅读FPN for object detection,看了网上的很多资料&#xff0c;有些认识是有问题的&#xff0c;当然有些很有价值。下面我自己总结了一下&#xff0c;以供参考。 1. FPN解决了什么问题&#xff1f; 答&#xff1a; 在以往的faster rcnn进行目标检测时&#xff0c;无论…

最近工作

最近的工作忙且乱&#xff0c;以至于&#xff0c;我第天早晨早早起来到晚上11点多才能回到家。今天早晨写代码的时候腰突然猛疼&#xff0c;疼的我直叫唤。躺在床上半天起不来。 最近每天的工作要计划一下了&#xff0c;不能客户说干嘛就干嘛&#xff0c;这样累坏了自己&#x…

LeetCode OJ - Candy

题目&#xff1a; There are N children standing in a line. Each child is assigned a rating value. You are giving candies to these children subjected to the following requirements: Each child must have at least one candy.Children with a higher rating get mor…

那些 IT 界的神翻译,原来我学不好编程的原因就在这

近日博主 ruanyf 在网上发布了一条关于套接字“socket”的解释&#xff0c;引发了网友对于那些 IT 界的神翻译的讨论&#xff1a; 突然想到&#xff0c;socket就是插座。服务器的socket&#xff0c;就是服务器提供插座&#xff0c;等着客户端的插头插进来。一旦插入完成&#x…

navicat 结构同步会加锁吗_被柜员怠慢的张小波,真的会永久地转走几个亿的结构性存款吗?...

4月7日下午&#xff0c;北京凤凰联动文化传媒有限公司总裁张小波发布微博称&#xff0c;前几天去安贞附近一银行&#xff0c;想把借记卡的转帐额度从每天五百万上调一下&#xff0c;没有想到&#xff0c;在其问到“最高可调到多少”时&#xff0c;柜员回答一个亿并“鄙夷地看了…

Mask RCNN笔记

mask rcnn简介 mask rcnn是何凯明基于以往的faster rcnn架构提出的新的卷积网络&#xff0c;一举完成了object instance segmentation. 该方法在有效地目标的同时完成了高质量的语义分割。 文章的主要思路就是把原有的Faster-RCNN进行扩展&#xff0c;添加一个分支使用现有的检…

IOS开发之----常用函数和常数--秀清

介绍一下Objective-c常用的函数&#xff0c;常数变量 算术函数 【算术函数】函数名说明int rand()随机数生成。&#xff08;例&#xff09;srand(time(nil)); //随机数初期化int val rand()P; //0&#xff5e;49之间的随机数int abs(int a)整数的绝对值&#xff08;例&#…

网页设计中常用的19个Web安全字体

来自http://www.jb51.net 在Web编码中&#xff0c;CSS默认应用的Web字体是有限的&#xff0c;虽然在新版本的CSS3&#xff0c;我们可以通过新增的font-face属性来引入特殊的浏览器加载字体。但多数情况下&#xff0c;考虑各个因素的影响我们还是在尽量充分利用这些默认调用的字…

python slice是共享内存吗_python共享内存实现进程通信

1.概述共享内存可以说是最有用的进程间通信方式.两个不同的进程共享内存的意思是:同一块物理内存被映射到两个进程的各自的进程地址空间.一个进程可以及时看到另一个进程对共享内存的更新,反之亦然.采用共享内存通信的一个显而易见的好处效率高,因为进程可以直接读写内存,而不需…

FCN-数据篇

从本篇开始&#xff0c;我们来记录一下全卷积网络用来做语义分割的全过程。 代码&#xff1a;https://github.com/shelhamer/fcn.berkeleyvision.org 下面我们将描述三方面的内容&#xff1a; 1. 官方提供的公开数据集 2. 自己的数据集如何准备&#xff0c;主要是如何标注…

深圳本地网店代运营公司

◆★◆深圳本地网店代运营&#xff0c;淘宝代运营多少钱&#xff0c;微博运营公司&#xff0c;代运营平台&#xff0c;天猫京东代运营&#xff0c;网站代运营图 片&#xff0c; 北京京东代运营&#xff0c;网店代运营协议&#xff0c;京东店铺代运营&#xff0c;网站代运营服务…

搜索专题题解

题目链接&#xff1a; codeforces 277A - Learning Languages 题目描述&#xff1a; 一个团体有n个人&#xff0c;每个人都掌握了一些语言&#xff0c;每个人学一门语言有1个花费&#xff0c;两个人之间可以通过其他人的翻译&#xff0c;问最少花费多少使得这个团体的任意两个人…

Facebook 开源的快速文本分类器 FastTex

FastText是Facebook开发的一款快速文本分类器&#xff0c;提供简单而高效的文本分类和表征学习的方法&#xff0c;性能比肩深度学习而且速度更快。 fastText 原理fastText 方法包含三部分&#xff1a;模型架构、层次 Softmax 和 N-gram 特征。下面我们一一介绍。 1.1 模型架构 …

FCN-加载训练与测试数据

当我们生成了数据后&#xff0c;我们来看看FCN是如何加载数据的。 FCN 代码预览 其中&#xff1a; - data : 训练测试数据 - ilsvrc-nets&#xff1a;存放预训练的模型 - 剩下的框&#xff1a;不同数据集的训练测试prototxt - voc_layers&#xff0c;siftflow_layers等&am…