返回顶部
首页 > 资讯 > 精选 >C#集合查询Linq在项目中如何使用
  • 738
分享到

C#集合查询Linq在项目中如何使用

2023-06-30 16:06:35 738人浏览 独家记忆
摘要

这篇文章主要介绍“C#集合查询Linq在项目中如何使用”,在日常操作中,相信很多人在C#集合查询Linq在项目中如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#集合查询Linq在项目中如何使用”的疑

这篇文章主要介绍“C#集合查询Linq在项目中如何使用”,在日常操作中,相信很多人在C#集合查询Linq在项目中如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#集合查询Linq在项目中如何使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

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时,还需要借助相关文档,多用几次,自然就不算什么问题了。

到此,关于“C#集合查询Linq在项目中如何使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: C#集合查询Linq在项目中如何使用

本文链接: https://lsjlt.com/news/330409.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C#集合查询Linq在项目中如何使用
    这篇文章主要介绍“C#集合查询Linq在项目中如何使用”,在日常操作中,相信很多人在C#集合查询Linq在项目中如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#集合查询Linq在项目中如何使用”的疑...
    99+
    2023-06-30
  • C#集合查询Linq在项目中使用详解
    目录Linq LambdaLinq项目中的一次使用经历Linq to js [在前端的应用]要说哪门后端语言的语法优雅,那就不得不提C#,而在我看来,LINQ语法可以说是其优雅的重要...
    99+
    2024-04-02
  • C#中如何使用LINQ查询数据
    C#中如何使用LINQ查询数据,需要具体代码示例LINQ(Language Integrated Query)是C#中的一种强大的查询语言,它可以帮助开发者简化对数据的查询和操作。本文将介绍如何在C#中使用LINQ查询数据,并提供具体的代码...
    99+
    2023-10-22
    C# 查询数据 C#中的关键词: LINQ
  • Linq 中如何使用City集合
    Linq 中如何使用City集合,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。因为我们将在好几个示例中重用这个Linq City集合,我决定把它封装到一个"Trave...
    99+
    2023-06-17
  • 怎么在c#中使用Linq查询语句
    怎么在c#中使用Linq查询语句?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Lambda表达式简介:      &...
    99+
    2023-06-14
  • 如何使用LINQ查询
    这篇文章主要介绍了如何使用LINQ查询,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。.NET Language Integrated Query (LINQ):采用通用方案来...
    99+
    2023-06-17
  • LINQ查询如何使用
    这篇文章主要讲解了“LINQ查询如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“LINQ查询如何使用”吧!LINQ查询成为了.NET中头等的编程概念,被查询的数据可以是XML(LINQ...
    99+
    2023-06-17
  • C#如何使用LINQ查询操作符
    这篇文章主要讲解了“C#如何使用LINQ查询操作符”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#如何使用LINQ查询操作符”吧!连表操作符1、内连接使用 join 子句 根据特定的条件合...
    99+
    2023-07-02
  • MySQL数据查询中如何使用集合/聚合函数查询
    小编给大家分享一下MySQL数据查询中如何使用集合/聚合函数查询,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!MySQL聚合函数如下:函数作用avg()返回某列的平均值count()返回某...
    99+
    2024-04-02
  • 如何使用LINQ查询结果
    这篇文章主要介绍了如何使用LINQ查询结果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。使用LINQ查询结果如果查询结果是强类型的,如string[],List<T&g...
    99+
    2023-06-17
  • Polly如何在c#项目中使用
    今天就跟大家聊聊有关Polly如何在c#项目中使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Polly是一个C#实现的弹性瞬时错误处理库它可以帮助我们做一些容错模式处理,比如:超...
    99+
    2023-06-14
  • 如何在C#项目中使用继承
    如何在C#项目中使用继承?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。声明一个抽象类//基类    abstract clas...
    99+
    2023-06-15
  • linq动态条件查询如何使用
    本篇内容主要讲解“linq动态条件查询如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“linq动态条件查询如何使用”吧!1,linq动态条件之构造表达式树private Expr...
    99+
    2023-06-17
  • 复合语句如何在Java项目中使用
    本篇文章为大家展示了复合语句如何在Java项目中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。        与 C 语言及...
    99+
    2023-05-31
    java 复合语句 ava
  • Java项目中如何使用集合实现添加元素
    本篇文章给大家分享的是有关Java项目中如何使用集合实现添加元素,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。初始化需要进行比较的集合,统一增加10万个元素,获取整个过程的执行...
    99+
    2023-05-31
    java 集合 添加元素
  • MySQL如何在查询中使用子查询
    MySQL中可以在查询中使用子查询来实现更复杂的查询逻辑。子查询是一个嵌套在主查询中的查询语句,通常用于获取主查询中某些条件的结果,...
    99+
    2024-03-06
    MySQL
  • 如何在C#项目中集成一个Lua脚本
    本篇文章为大家展示了如何在C#项目中集成一个Lua脚本,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。步骤1 引入NLua.dll  这个dll是一个很轻量级的库,100kb左右,引用这个库可以通过N...
    99+
    2023-06-06
  • 如何使用mongoose实现多集合关联查询
    这篇文章主要介绍了如何使用mongoose实现多集合关联查询,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在使用node开发后端项目的时候,通常会选择mongodb作为数据库...
    99+
    2023-06-29
  • 如何在C#项目中调用WebApi
    如何在C#项目中调用WebApi?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1.WebRequest方式Post:private void butto...
    99+
    2023-06-14
  • SpringBoot项目中使用JPA如何实现表关联查询
    SpringBoot项目中使用JPA如何实现表关联查询?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。例子中总共有两个实体类,一个是Floor(商品楼层类),另一个是FloorC...
    99+
    2023-05-31
    springboot jpa 表关联查询
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作