首页 > 编程语言 >C#中Linq常用用法

C#中Linq常用用法

时间:2022-08-28 20:55:47浏览次数:50  
标签:ToList C# List Linq 用法 rpId var new select

1、linq中交集、并集、差集的用法

简单的交集、并集、差集用法如下:

List<string> ListA = new List<string>();
List<string> ListB = new List<string>();
List<string> ListResult = new List<string>();

ListResult = ListA.Distinct().ToList();//去重
ListResult = ListA.Except(ListB).ToList();//差集
ListResult = ListA.Union(ListB).ToList();  //并集
ListResult = ListA.Intersect(ListB).ToList();//交集

若上面的例子不是List<string>类型,而是List<XXXModel>,则需要对XXXModel进行处理。
步骤如下:
(1)先定义Model。

public class ItemModel
{
   public string ItemCode { get; set; }
   public string ItemName { get; set; }
}

(2)定义如何Model间如何比较。若不定义,比较的是两个引用。

public class ItemModelComparer : IEqualityComparer<ItemModel>
{
        //比较
        public bool Equals(ItemModel x, ItemModel y)
        {
            bool checkFlag = true;
            if (Object.ReferenceEquals(x, y))
            {
                checkFlag = true;
            }
            else if (Object.ReferenceEquals(x, null) || Object.ReferenceEquals(y, null))
            {
checkFlag = false; } else { if (x.ItemCode == y.ItemCode) //若Model有多个条件则需要添加。例如 if(x.ItemCode==y.ItemCode && x.Other==y.Other) { checkFlag = true; } else { checkFlag = false; } } return checkFlag; } //实现获取哈希值 public int GetHashCode(ItemModel model) { if (Object.ReferenceEquals(model, null)) return 0; int hashNurse = model.ItemCode.GetHashCode(); // 若有多个条件,则哈希值也需要进行计算 // int hashOther=model.Other.GetHashCode(); // int resultHash=hashNurse^hashOther; // return resultHash; return hashNurse; } }

(3)具体使用如下

List<ItemModel> ListA = new List<ItemModel>();
List<ItemModel> ListB = new List<ItemModel>();
List<ItemModel> ListResult = new List<ItemModel>();

ListResult = ListA.Distinct(new ItemModelComparer()).ToList();//去重
ListResult = ListA.Except(ListB, new ItemModelComparer()).ToList();//差集
ListResult = ListA.Union(ListB, new ItemModelComparer()).ToList();  //并集
ListResult = ListA.Intersect(ListB, new ItemModelComparer()).ToList();//交集

2、 join的用法

若出现两个List,想用Linq进行查询。则可以使用如下的方式

int tempSatisfiedConditionCount = (from r1 in whiteList
                                   join r2 in args.DiagList on r1.DiagCode equals r2.DiagCode
                                   select r1).Count();

多条件的join

//多条件的联合查核
List<DiagControlModel> whiteDiagList = (from r1 in diagControlList
        where r1.ControlRelation == 1
        join r2 in args.DiagList on new { code = r1.DiagCode, name = r1.DiagName }
        equals new{code=r2.DiagCode,name=r2.DiagName}
        select r1).ToList<DiagControlModel>();

另外,join还可以用于左连接/右连接

var LeftJoin = from emp in ListOfEmployees
                join dept in ListOfDepartment
                on emp.DeptID equals dept.ID into JoinedEmpDept
                from dept in JoinedEmpDept.DefaultIfEmpty()
                 select new
                      {
                            EmployeeName = emp.Name,
                            DepartmentName = dept != null ? dept.Name : null
                      };

3、let用法

let是一个在linq中定义局部变量
1、可以有多个let子句
2、let后的变量无需声明类型
参见下例:

var query = from a in list  
                        let b = a.Name.Split('-')  
                        let c=a.Age  
                        where b[0] =="zhangs" & c>21  
                        select a; 

4、分组

常用的分组用法:

var linqtest = from r in db.Am_recProScheme
               orderby r.rpId descending
               group r by r.recType into n
               select new
               {
                    n.Key,  //这个Key是recType
                    rpId = n.Sum(r => r.rpId), //组内rpId之和
                    MaxRpId = n.Max(r => r.rpId),//组内最大rpId
                    MinRpId = n.Min(r => r.rpId), //组内最小rpId
               };

略微复杂点:

var dataList= (from r in drugLabelList
               group r by new
               {
                  r.OrderNo,
                  r.PatientID,
                  r.PatientName
               } into q
               let drugAmount = q.Sum(t => Convert.ToInt32(t.ChargeAmount))
               where drugAmount >= 0
               select new PrintDrugLabelModel
               {
                  OrderNo = q.Key.OrderNo,
                  PatientID = q.Key.PatientID,
                  PatientName = q.Key.PatientName,
                  ChargeAmount = ""+drugAmount
               }).ToList<PrintDrugLabelModel>();

5、简单的函数计算

 var linqtest = (from r in db.Am_recProScheme
                 select r).Sum(p => p.rpId);

6、排序order by desc/asc

var linqtest = (from r in db.Am_recProScheme
                where r.rpId > 10
                orderby r.rpId descending  //倒序
                // orderby r.rpId, r.rpname descending   //多条件的倒序(与SQL语句中的相同)
                //  orderby r.rpId ascending   //正序
                select r);

7、top(1)

//如果取最后一个可以按倒叙排列再取值
 var linqtest = (from r in db.Am_recProScheme                     
                 select r).FirstOrDefault();

8、跳过前面多少条数据取余下的数据

var linqtest = (from r in db.Am_recProScheme
                where r.rpId > 10
                orderby r.rpId descending
                select r).Skip(10).Take(10); //取第11条到第20条数据  

9、包含

//可以使用List、Array、string的Contains()方法进行判断
 var linqtest = (from r in db.Am_recProScheme
                 where r.SortsText.Contains("张")
                 select r);

10、连接查询

var linqtest = (from r in db.Am_recProScheme
                join w in db.Am_Test_Result on r.rpId equals w.rsId
                orderby r.rpId descending
                select r);

11、使用linq查询DataTable

 //遍历DataTable,将其中的数据对应到ClientStruct中:  
 List<ClientStruct> list = (from x in dtTable.AsEnumerable()  
                            orderby x.Field<string>("")  descending  
                            where x.Field<string>("ErrorType") == "漏孔" 
                            select new ClientStruct  
                            {  
                               ID = x.Field<string>(cs.ID),  
                               Name = x.Field<string>(cs.Name),  
                               Company = x.Field<string>(cs.Company),  
                               CreatedDate = x.Field<string>(cs.CreatedDate)  
                            }).ToList<ClientStruct>();  

12、linq中列传行操作(Aggregate的使用)—2022-3-4

解决分组又聚合的问题。
后台数据存储的样式是:

 

希望实现:

 

 即:实现分组,并且能将诊断进行聚合(列转行)
linq的写法如下:

var data_list = (from r in temp_result_list
                 group r by new
                      {
                          r.DrugCode,
                          r.VisitType
                      } into q
                  select q.Aggregate(temp_result_list[0],(workingSentence, next) => new DiagControlModel
                  {
                      DrugCode = q.Key.DrugCode,
                      VisitType = q.Key.VisitType,
                                     DiagInfoStr =  workingSentence.DiagInfoStr + ";" + next.DiagName
                  })).ToList<DiagControlModel>();

 

标签:ToList,C#,List,Linq,用法,rpId,var,new,select
From: https://www.cnblogs.com/lgx5/p/16633621.html

相关文章

  • leetcode191:位1的个数
    packagecom.mxnet;publicclassSolution191{publicstaticvoidmain(String[]args){System.out.println(1<<5);}/***编写一......
  • Model断开连接建议与Db::close()的bug
    Model断开连接建议与Db::close()的bug-ThinkPHP框架 https://www.thinkphp.cn/bug/1820.html1、建议Model类增加一个close方法,用于断开数据库连接。高并发的时候效果......
  • C++中 sort()和priority_queue()中的自定义比较
    C++sort/priority_queue自定义比较sort/priority_queue的自定义比较是有区别的:sort是自定义函数;priority_queue则是自定义结构体,结构体里面重载()实现自定义比较......
  • Educational Codeforces Round 134 E - Prefix Function Queries补题
    原题链接参考了jly的写法#pragmaGCCoptimize(2)#include<bits/stdc++.h>usingnamespacestd;#definefrfirst#definesesecond#defineet0exit(0);#define......
  • 学习ASP.NET Core Blazor编程系列二——第一个Blazor应用程序(上)
    学习ASP.NETCoreBlazor编程系列一——综述一、概述      Blazor是一个生成交互式客户端WebUI的框架: 使用C#代替JavaScript来创建信息丰富的交互式......
  • PHP 重载方法 __call()
    PHP重载方法__call()_PHP基础教程-我爱开发网 http://www.5idev.com/p-php_method_overloading.shtml__call()方法用于监视错误的方法调用。__call()(Methodove......
  • Smarty {foreach},{foreachelse}
    {foreach},{foreachelse} http://www.speedphp.com/smarty/language.function.foreach.html#foreach.property.first{foreach},{foreachelse}{foreach}用于循环数组......
  • vue——nextTick函数
    一.nextTick的作用Vue.nextTick作用是在下一次DOM更新结束后执行其指定的回调。。那么我们的理解是:当数据发生变化之后,DOM视图并不会立即更新,如果我们在发生变化之......
  • tcpip详解-读书笔记
    TCP/IP详解卷一第一版读书笔记第一章:应用层关心是应用程序的细节,而不是数据在网络中对的传输活动,下三层对应用程序一无所知,但他们要处理所有的通信细节。七层代理可......
  • Linux上安装并启动tomcat
    1、下载tomcat安装包官网链接:https://archive.apache.org/dist/tomcat/tomcat-7/v7.0.57/bin/一般选择 2、将tomcat上传到Linux服务器网上有很多文件传输工具,我使用......