C#集合查询Linq在项目中使用详解
作者:握风 发布时间:2022-09-16 13:50:09
要说哪门后端语言的语法优雅,那就不得不提C#,而在我看来,LINQ语法可以说是其优雅的重要一环!
通常后端从数据库查询出来的数据并不是直接返回给前端使用的(不然前端....),而是需要进行二次的加工筛选处理等操作!而这个操作就离不开LINQ,不然for循环套for循环,先不说可不可行,肯定可行,但是代码的可读性完全丢失,其他同行看到也会笑话人,连编译器运行这段代码时也是发尽牢骚(....),从而导致程序的性能低下!
当然如果用SQL一次性把数据处理到位也行,但是实际项目开发中,很少能一次处理到位的,往往都需要二次处理(比如:我不仅需要List,还需要统计信息,总数、均值,总和等)
Linq Lambda
说到Linq,就不得不提Lambda表达式了,说实话,实际开发中,直接用Linq写的相关代码还真不多,Lambda表达式到处都是!
先上代码,直观看看他们两者有什么区别
static void Main(string[] args)
{
List<User> users = new List<User>();
var letters = "abcdefghijklmnopqrstuvwxyz";
var rand = new Random();
for (int i = 0; i < 10; i++)
{
string name = default;
for(int j = 0; j < 4; j++)
{
name += letters[rand.Next(25)];
}
users.Add(new User { Name = name, Age = rand.Next(1, 99) });
}
//Linq
IEnumerable<User> usera = from u in users where u.Age < 35 select u;
//usera.ToList();
//Lambda
List<User> userb = users.Where(x => x.Age < 35).ToList();
//输出来看看
foreach(User u in usera)
{
Console.WriteLine("name:{0},age:{1} \n", u.Name, u.Age);
}
Console.WriteLine("------------------");
foreach (User u in userb)
{
Console.WriteLine("name:{0},age:{1} \n", u.Name, u.Age);
}
Console.ReadLine();
}
class User
{
public string Name { get; set; }
public int Age { get; set; }
}
看完代码,是不是感觉Linq跟SQL差不多,对,本来他们就是类似语言,我个人猜测应该是模仿出来的一种语法糖吧(具体谁模仿谁就不得而知了),相似也好,学起来更方便了。而Lambda表达式写起来是真的舒服!
那么,Linq和Lambda有什么关系呢
包含的关系,Linq范围更广一些,Lambda表达式看起来像一个箭头函数,就是!,也可以说是一个匿名函数!他相当于Linq的二次封装语法糖吧(个人理解)
基本上Linq能实现的,Lambda表达式都可以实现
通常沟通中,说Linq写法,其实默认就是Linq Lambda表达式了。直接链式写法,简洁,可读性,后期维护起来也是非常方便的。
众所周知,SQL能实现的功能是非常强大的,而Linq同样可以实现。
但实际开发中,SQL一般会写的相当复杂,聚合查询是常事,而Linq一般很少涉及(也能多表查询),更多的是诸如去重、筛选、排序、分组、统计计算等操作
Linq项目中的一次使用经历
获取不同用户的权限菜单 当用户登录时,可以获取到用户的权限菜单集合(id集合),而具体展示菜单,还需要到全部菜单集合中去查找对应的,然后筛选出来,返回给前端,最后进行渲染展示!
如果菜单集合List全都是一级菜单,那相当简单,但是如果有二级、 * 菜单就比较麻烦了,在这个筛选过程中,我就用到了Linq来实现部分功能
//powers 用户权限菜单集合
//menus 全部菜单集合
//menus.SubItems 二级菜单集合
(from sub in menus.SubItems where powers.Any(x=>x.Key == sub.Id) select sub).Count()
如上代码段,可以获取到当前菜单的子菜单的个数
如果不加外层的Count(),那结果就是当前菜单子菜单(此用户有权限的)集合
如果不采用Linq,一行代码很难实现(方法还是有的,只是不会Linq那么方便写)
Linq to js [在前端的应用]
LINQ其实并不是后端语言的专属,前端同样可以使用,只需要引用相应的js插件即可
js、vue等项目中都有对应的插件(例如jslinq),仅需要对应的组件中引入插件(也可以在母版页或全局引用),然后就可以像后端语言中一样的使用即可。
具体写法与后端语言差不多,常用方法名也都一样
要说不一样的地方,我感觉唯一不好的体验就是,前端使用时,没有代码提示了,如果对LINQ不太熟悉的,在使用LINQ时,还需要借助相关文档,多用几次,自然就不算什么问题了。
这里就不展开细说Linq在前端的具体用法了,需要的可以自行查询,这里仅做一个抛砖引玉的效果。
来源:https://juejin.cn/post/7102648407491739679


猜你喜欢
- 一、返回值格式统一1.返回值介绍在使用controller对外提供服务的时候,很多时候都需要统一返回值格式,例如{"status&
- Android在自定义控件时,经常需要获得屏幕的宽高,每次都要写,不妨直接把他封装成工具类,直接拿来用,废话不说,直接上代码/** * &n
- 前言任何使用过基于 Java 的企业级后端应用的软件开发者都会遇到过这种低劣、奇怪的报错,这些报错来自于用户或是测试工程师: java.la
- JVM 的主要作用是什么?JVM 就是 Java Virtual Machine(Java虚拟机)的缩写,JVM 屏蔽了与具体操作系统平台相
- 找入口对 Spring 有一定基础的同学一定知道,请求入口是DispatcherServlet,所有的请求最终都会落到doDispatch方
- 简介在之前spring boot3文章中我们介绍了,spring boot3的一个重要特性就是支持把spring boot3的应用编译成为G
- 前言:平时在实际工作中很少用到这个,虽然都是一些比较基础的东西,但一旦遇到了,又不知所云。刚好最近接触了一些相关这方面的项目,所以也算是对
- 小编在之前给大家介绍过很多android项目打包的经验,本篇内容我们通过一个项目实例来给大家讲解android每一步打包和签名的过程。and
- 一、简介:开发中在用户注册或找回密码之类的功能,经常会遇到获取短信验证码,获取验证码后需要等待1分钟倒计时,这段时间是不能再次发送短信请求的
- 起源flutter作为一个跨平台的框架,在绘制上体现出了它跨平台的良好性能.那么,它是如何从runApp()后 绘制上屏的呢?本文将与你一起
- 先看看常规的隐藏状态栏的方法:方法一:@Overrideprotected void onCreate(Bundle savedInstan
- C#调用Twain接口实现扫描仪连续扫描。在监听的TwainCommand.TransferReady状态中,是调用扫描仪扫描图片的。我开始
- Message的创建消息Message一般不支持大家直接通过new的方式进行创建的,因为Message作为Android系统中使用频率非常高
- 熟悉Eclipse的都知道Eclipse经常性的会出现一些莫名其妙的问题,有时候运行的好好的突然重启一下项目就莫名的报错,所以经常会用到cl
- 1.Fanout Exchange介绍Fanout Exchange 消息广播的模式,不管路由键或者是路由模式,会把消息发给绑定给它的全部队
- 1、SpringMVC中默认集成SpringMVC已经默认集成了JackSon,如下所示: @RequestMapping(&q
- 一、为何要使用netty开发由于之前已经用Java中的socket写过一版简单的聊天室,这里就不再对聊天室的具体架构进行细致的介绍了,主要关
- 前言为啥需要学Feign呢?我们先来回顾之前写的代码先来看我们以前利用RestTemplate发起远程调用的代码:这里就有几个问题:代码可读
- 一、TkMybatisTkmybatis 是基于 Mybatis 框架开发的一个工具,通过调用它提供的方法实现对单表的数据操作,不需要写任何
- 目录什么是Spring的占位符?Spring什么时候去解析并占位符什么是Spring的占位符?在以前的Spring Xml配置中我们可能会有