最近工作中遇到一个这样的需求:在某个列表查询功能中,可以选择某个数字列(如商品单价.当天销售额.当月销售额等),再选择 小于或等于 和 大于或等于 ,再填写一个待比较的数值,对数据进行查询过滤. 如果只有一两个这样的数字列,那么使用 Entity Framework Core 可以这么写 LINQ 查询: public Task<List<Product>> GetProductsAsync(string propertyToFilter, MathOperator mathOpe…
通过动态构建Expression Select表达式并创建动态类型来控制Property可见性 项目中经常遇到的一个场景,根据当前登录用户权限,仅返回权限内可见的内容.参考了很多开源框架,更多的是在ViewModel层面硬编码实现.这种方式太过繁琐,每个需要相应逻辑的地方都要写一遍.经过研究,笔者提供另外一种实现,目前已经应用到项目中.这里记录一下,也希望能给需要的人提供一个参考. 1.定义用于Property可见性的属性PermissionAttribute PermissionAttribu…
LINQ查询表达式---------where子句 where 子句用在查询表达式中,用于指定将在查询表达式中返回数据源中的哪些元素. 它将一个布尔条件(“谓词”)应用于每个源元素(由范围变量引用),并返回满足指定条件的元素. 一个查询表达式可以包含多个 where 子句,一个子句可以包含多个谓词子表达式. 1.1 常见的where子句查询 static void Main(string[] args) { , , , , , , , , , }; var num1 = from n in nu…
本节我们主要介绍一下如何创建查询集合类型,关系数据库类型,DataSet对象类型和XML类型的数据源的Linq查询表达式. 下面在实例代码ReadyCollectionData()函数创建了准备的数据源: 1.创建集合类型的查询. 创建一个UserBaseInfo类: public class UserBaseInfo { private List<string> aliasname; private int id; private string email; private int role…
本篇讲解LINQ查询的三种形式: 查询对象 自定义查询对象某个属性 查询匿名类型结果 [1.查询结果返回集合元素] 在LINQ查询中,select子句和from子句都是必备子句.LINQ查询表达式必须以select或group子句结束.select子句指定在执行查询时产生结果的数据集中元素的类型,它的格式如下: select element 其中,select是关键字,element参数则指定查询结果中元素的类型及初始化方式. 在进一步介绍select子句之前,首先简单介绍一下本章例子中要用到的…
LINQ查询表达式---------let子句 let子句创建一个范围变量来存储结果,变量被创建后,不能修改或把其他表达式的结果重新赋值给它.此范围变量可以再后续的LINQ子句中使用. class Program { static void Main(string[] args) { , , , , , , }; var query = from num in number let n = num % select num; foreach (var item in query) { Conso…
LINQ查询表达式---------join子句 join 子句接受两个源序列作为输入. 每个序列中的元素都必须是可以与另一个序列中的相应属性进行比较的属性,或者包含一个这样的属性. join子句使用特殊的 equals 关键字比较指定的键是否相等. join 子句执行的所有联接都是同等联接. join 子句的输出形式取决于所执行的联接的具体类型. 以下是三种最常见的联接类型: 内部联接 分组联接 左外部联接 class Program { public class PerInfo { publ…
LINQ查询表达式---------orderby子句 LINQ可以按元素的一个或多个属性对元素进行排序. class Program { public class PerInfo { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } } static void Main(string[] args) { List<PerInfo> perInfos = new L…
LINQ查询表达式---------into into 上下文关键字创建一个临时标识符,以便将 group.join 或 select 子句的结果存储到新的标识符 class Program { public class PerInfo { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } } static void Main(string[] args) { //i…
LINQ查询表达式---------group子句 LINQ表达式必须以from子句开头,以select或group子句结束.使用guoup子句来返回元素分组后的结果.group 子句返回一个 IGrouping<TKey, TElement> 对象序列(实质上是列表的列表).TKey是键的对象类型,在用于group子句的时候,它一般用于存储分组的键值:TElement是指的对象类型,用于存储分组的结果. class Program { public class PerInfo { publi…