Linq基础语法

LINQ概述

LINQ(Language Integrated Query,语言集成查询)提供了一种跨数据源和数据格式查询的统一模型。

LINQ的组成:

  1. LINQ To Objects:查询集合对象
  2. LINQ enabled ADO.NET:查询数据库

     LINQ To DataSet

     LINQ To SQL

     LINQ To Entities -> EntityFramework
  3. LINQ To XML:查询XML文档

LINQ的语法:

from [type] id in source

[join [type] id in source on expr equals expr [into subGroup]]

[from [type] id in source | let id = expr | where condition]

[orderby ordering,ordering,ordering…]

select expr | group expr by key

[into id query]

注意:只有实现了IEnumerable接口的数据源,才能执行相关的LINQ操作

LINQ方法语法基础

1、方法语法的是通过扩展方法和Lambda表达式来创建查询。

查询语法和方法语法在语义上是相同的,但是大多数情况下发现查询语法更简单且更易于阅读;并且某些查询必须表示为方法调用(比如聚合操作)。

看上述概念大家可能有点不懂什么意思,下面我们用两个简单的案例来进行分析。

首先我们先来三个常用扩展方法, Where(筛选操作)、OrderBy(排序操作)、Select(投影操作)

StubentIfo类

//StubentIfo类
class StubentIfo
{
public int Id { get; set; }
public string Name { get; set; }
public string Sex { get; set; }
public int Age { get; set; }
public string Address { get; set; }
public string Phone { get; set; }
public string Email { get; set; }
}

初始化数据

//初始化数据
List<StubentIfo> list = new List<StubentIfo>();
list.Add(new StubentIfo{Id = 1,Name="张三", Sex="男", Age=38, Address="唐山", Email="111", Phone="165412164321" });
list.Add(new StubentIfo{Id = 2, Name = "张4", Sex = "女", Age = 17, Address = "唐山", Email = "111", Phone = "7355165123431" });
list.Add(new StubentIfo{ Id = 3, Name = "张5", Sex = "女", Age = 18, Address = "唐山", Email = "111", Phone = "165412164321"});
list.Add(new StubentIfo{ Id = 4, Name = "张6", Sex = "男", Age = 88, Address = "唐山", Email = "111", Phone = "564354631521" });
list.Add(new StubentIfo{ Id = 5, Name = "张7", Sex = "男", Age = 48, Address = "唐山", Email = "111", Phone = "87123412035" });

案例的数据在已经创建好了,下面我们来进行我们的第一个小练习。

例1

在以上数据中筛选出女性用户、并按用户的年龄进行排序。

var lianxi2 = from x in list //数据源
where x.Sex == "女" //判断条件
orderby x.Age descending //排序
select x;
//foreach 循环lianxi2,输出结果
foreach (var item in lianxi2)
{
Console.WriteLine($"编号:{item.Id} 姓名:{item.Name} 性别:{item.Sex} 年龄:{item.Age} 地址:{item.Address} 邮箱:{item.Email} 电话:{item.Phone} ");
}

展示

例2

查询最高的文综成绩,并将文科学生按照文综成绩降序排列输出

Student类和Score类

 	class Student
{
public int Id { get; set; }
public string Name { get; set; }
public bool Arts { get; set; }//是否是文科
public Score Scores { get; set; }//成绩类
}
/// <summary>
/// 成绩
/// </summary> class Score
{
public int Chinese { get; set; }
public int Maths { get; set; }
public int EngLish { get; set; }
public int Comprehensive { get; set; } //总成绩 }

数据添加

static List<Student> students = new List<Student>()
{
new Student{Id=1,Name="张1",Arts=false, Scores=new Score{Chinese=127,Maths=145,EngLish=122,Comprehensive=289}},
new Student{Id=2,Name="张2",Arts=true, Scores=new Score{Chinese=103,Maths=145,EngLish=122,Comprehensive=250}},
new Student{Id=3,Name="张3",Arts=true, Scores=new Score{Chinese=136,Maths=102,EngLish=122,Comprehensive=189}},
new Student{Id=4,Name="张4",Arts=true, Scores=new Score{Chinese=126,Maths=145,EngLish=140,Comprehensive=238}},
};

查询语句

			var data = students.Where(s => s.Arts == true).Max(s=>s.Scores.Comprehensive);
var data1 = students.Where(s => s.Arts == true).OrderByDescending(s => s.Scores.Comprehensive);
Console.WriteLine("最高的文综成绩:"+data);
Console.WriteLine("按照文综成绩降序排列如下:");
Console.WriteLine("编号\t姓名\t语文\t数学\t英语\t综合");
foreach (var item in data1)
{
Console.WriteLine($"{item.Id}\t{item.Name}\t{item.Scores.Chinese}\t{item.Scores.Maths}\t{item.Scores.EngLish}\t{item.Scores.Comprehensive}");
}

结果展示



从上述案例可以看出Linq查询的两种方式基础代码不多,且非常好用,可以在开发是按自己的需求来进行选择。

EntityFramework数据持久化 Linq语法应用的更多相关文章

  1. EntityFramework数据持久化 Linq介绍

    一.LINQ概述与查询语法 二.LINQ方法语法基础(重点) 三.LINQ聚合操作与元素操作(重点) 四.数据类型转换(重点) 一.LINQ概述与查询语法 1.LINQ(Language Integr ...

  2. Linq To Sql中实现Left Join与Inner Join使用Linq语法与lambda表达式

    当前有两个表,sgroup与sgroupuser,两者通过gKey关联,而sgroup表记录的是组,而sgroupuser记录是组中的用户,因此在sgroupuser中不一定有数据.需要使用Left ...

  3. MVC之实体框架(数据持久化框架)EntityFrameWork(EF)

    EF - EntityFrameWork 中文名:实体框架(数据持久化框架) 1.使用EF查询(Linq to EF) 1.1使用标准查询运算符来查询 OumindBlogEntities db = ...

  4. vue render函数使用jsx语法 可以使用v-model语法 vuex实现数据持久化

    render函数使用jsx语法: 安装插件  transform-vue-jsx 可以使用v-model语法安装插件 jsx-v-model .babelrc文件配置: vuex实现数据持久化 安装插 ...

  5. Mongodb C#客户端数据关联数据,使用Linq语法进行关联

    在Mongodb C# drivers 文档 官方地址:https://docs.mongodb.com/ecosystem/drivers/csharp/ 基础的使用请参考<c# Mongod ...

  6. Code First开发系列之管理数据库创建,填充种子数据以及LINQ操作详解

    返回<8天掌握EF的Code First开发>总目录 本篇目录 管理数据库创建 管理数据库连接 管理数据库初始化 填充种子数据 LINQ to Entities详解 什么是LINQ to ...

  7. 【开源】OSharp框架解说系列(5.1):EntityFramework数据层设计

    OSharp是什么? OSharp是个快速开发框架,但不是一个大而全的包罗万象的框架,严格的说,OSharp中什么都没有实现.与其他大而全的框架最大的不同点,就是OSharp只做抽象封装,不做实现.依 ...

  8. iOS 数据持久化(扩展知识:模糊背景效果和密码保护功能)

    本篇随笔除了介绍 iOS 数据持久化知识之外,还贯穿了以下内容: (1)自定义 TableView,结合 block 从 ViewController 中分离出 View,轻 ViewControll ...

  9. Linq语法详细

    闲言碎语 近期比较忙,但还是想写点什么,就分享一些基础的知识给大家看吧,希望能帮助一些linq新手,如果有其它疑问,可以进右上角群,进行交流探讨,谢谢. 开门见山 读这篇文章之前,我先说下,每一种搜索 ...

随机推荐

  1. SpringMVC源码学习:容器初始化+MVC初始化+请求分发处理+参数解析+返回值解析+视图解析

    目录 一.前言 二.初始化 1. 容器初始化 根容器查找的方法 容器创建的方法 加载配置文件信息 2. MVC的初始化 文件上传解析器 区域信息解析器 handler映射信息解析 3. Handler ...

  2. Android中限制输入框最大输入长度

    通常情况下只需要在布局文件中加入maxlength这一属性即可 <EditText android:inputType="text" android:singleLine=& ...

  3. javaScript 添加和移除class类名的几种方法

    添加类属性: // 一次只能设置一个类值,如果当前属性本身存在类值,会被替换 element.className = '类名'; /* * .setAttribute 用来设置自定义属性和值的 * 自 ...

  4. GitHub 热点速览 Vol.19:如何叩响大厂的门?

    作者:HelloGitHub-小鱼干 摘要:进大厂,无疑是升职加薪走上人生巅峰的一个敲门砖,那,如何拿到这个敲门砖呢?前辈的经验之谈,无疑会给我们进大厂带来许多的经验参考,本周的#大厂面试经验之谈#主 ...

  5. 【OracleDB】 01 概述和基本操作

    实例概念: Oracle有一个特殊的概念 Oracle数据库 = 数据库 + Oracle文件系统 + Oracle实例 实例处理Oracle的请求,调用文件系统 然后返回结果响应给客户端 单实例和多 ...

  6. vim(vi)的常用快捷键

    Vim 简介 vim是什么?听说它是编辑器之神!神一样的存在,而我却经常用上下左右箭头来移动光标,实在是有点对不起它,所以想着稍微学学一点神的技能吧! 一. vim的三种模式 Nomal mode:默 ...

  7. 掌握这10种方法帮你快速在Linux上分析二进制文件

    我们每天都使用二进制文件,但对二进制文件知之甚少.二进制是指您每天运行的可执行文件,从命令行工具到成熟的应用程序.Linux提供了丰富的工具集,可轻松进行二进制分析!无论您的工作角色是什么,如果您在L ...

  8. PHP中面向对象特性实现

    PHP近些年来成为全球最流行的网页编程语言,该语言以弱类型.易兼容.门槛低.开发快.功能强著称,且听别人这么说,我在有了c和c#基础后学习PHP过程中也并不是很顺利,该语言的一些特殊的语法规则又是让我 ...

  9. React:Conditional Rendering(条件渲染)

    就像JS中常常会根据条件(比如if/else.switch)返回不同的值,React中也可以根据组件的状态或其他参考条件返回不同的React Element. 比如根据用户是否登陆渲染对应的UI面板. ...

  10. 中国空气质量在线监测分析平台之JS加密、JS混淆处理

    中国空气质量在线监测分析平台数据爬取分析 页面分析:确定url.请求方式.请求参数.响应数据 1.访问网站首页:https://www.aqistudy.cn/html/city_detail.htm ...