博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
用linqPad帮助你快速学习LINQ
阅读量:5107 次
发布时间:2019-06-13

本文共 2704 字,大约阅读时间需要 9 分钟。

在这里我向大家推荐的一个具是LinqPad有了这个工具并熟练使用就可以很快学习并掌握linq

linqPad下载地址:

它也自带了很多例子方便大家查询,linqPad支持object ,xml,sql ,  to linq这里我只讲一下sql to linq

好多同学不知道怎么用linq完成 left join ,inner join 等,这里我就用这个工具给大家实现一下

linqpad 会给我们同时生成lambda表达式,sql和IL 我一般情况下有linq的lambda不会的时候,就用Linqpad来调试得到结果

打开它的主页面看一下,点AddConnection 就可以添加数据库连接

 先在数据库里建一个库MyDataDemo两个表Classes和Student

create database MyDataDemogo use MyDataDemogodrop table Studentcreate table Classes(    class_Id int ,    class_Name varchar(100))create table Student(    st_Id int,    st_Name varchar(100),    class_Id int)insert into Classes values(1,'OneC')insert into Classes values(2,'TwoC')insert into Classes values(3,'ThreeC')insert into Student values(1,'xiaoMing',1)insert into Student values(2,'zhangqiang',2)insert into Student values(3,'lihong',3)insert into Student values(4,'wangsi',1)insert into Student values(5,'zhaoWu',1)insert into Student values(6,'WangLiu',2)
数据库里建两个表

 我们在linqPad的query标签里把Language 选择为c# Expression ,把Connection 选择数据MyDataDemo 就是我们上边建好的数据库如图

先看一下Left Join

我们在面版里输入最基本的Linq表达式 点执行或者F5

from stu in Studentsjoin cla in Classeson stu.Class_Id equals cla.Class_Idinto MyJoinfrom grp in MyJoin.DefaultIfEmpty()select new {ClassId=grp.Class_Id,Class_Name=grp.Class_Name,st_Name =stu.St_Name}

看一下linqPad给我们显示的结果

sql结果 是判断我们的Linq是不是正确的

看它是left outer join(left join 是Left outer join 和简写) 证明我们是正确的

SELECT [t1].[class_Id] AS [ClassId], [t1].[class_Name] AS [Class_Name], [t0].[st_Name]FROM [Student] AS [t0]LEFT OUTER JOIN [Classes] AS [t1] ON [t0].[class_Id] = [t1].[class_Id]

最强的是它还给我们生成lambda表达式

Students   .GroupJoin (      Classes,       stu => stu.Class_Id,       cla => cla.Class_Id,       (stu, MyJoin) =>          new           {            stu = stu,             MyJoin = MyJoin         }   )   .SelectMany (      temp0 => temp0.MyJoin.DefaultIfEmpty (),       (temp0, grp) =>          new           {            ClassId = grp.Class_Id,             Class_Name = grp.Class_Name,             st_Name = temp0.stu.St_Name         }   )

再看一下inner join

//inner join from stu in Studentsjoin cla in Classeson stu.Class_Id equals cla.Class_Idselect new {ClassId=cla.Class_Id,Class_Name=cla.Class_Name,st_Name =stu.St_Name}

看一下sql结果我们是不是正确的

SELECT [t1].[class_Id] AS [ClassId], [t1].[class_Name] AS [Class_Name], [t0].[st_Name]FROM [Student] AS [t0]INNER JOIN [Classes] AS [t1] ON [t0].[class_Id] = [t1].[class_Id]

正确

再看一下lambda表达式

Students   .Join (      Classes,       stu => stu.Class_Id,       cla => cla.Class_Id,       (stu, cla) =>          new           {            ClassId = cla.Class_Id,             Class_Name = cla.Class_Name,             st_Name = stu.St_Name         }   )

就讲到这里大家可以多学习一下这个工具

 

转载于:https://www.cnblogs.com/li-peng/p/3441729.html

你可能感兴趣的文章
反射---hasattr、getattr、setattr、delattr
查看>>
BZOJ 4407 于神之怒加强版
查看>>
传递对象与返回对象不是两回事
查看>>
C#注释标签的练习
查看>>
BitSet源码
查看>>
Word 2010中利用尾注添加参考文献(论文必备)
查看>>
Java 调用 Javascript 函数的范例
查看>>
With...End With 语句
查看>>
[Flex] ButtonBar系列——flex3 皮肤和外观设置
查看>>
XML外部实体注入漏洞(XXE)
查看>>
保存页面数据的场所----Hidden、ViewState、ControlState
查看>>
Python3.6全栈开发实例[015]
查看>>
eval函数使用技巧
查看>>
信息安全系统设计基础实验二—20135215黄伟业20135222胡御风
查看>>
Jupyter Notebook 的快捷键
查看>>
实现 页面某些 效果
查看>>
SharePoint Data View Conditional Formatting based on user permissions (IfHasRights)
查看>>
poj_3352 连通图的桥
查看>>
HDOJ HDU 2067 小兔的棋盘 ACM 2067 IN HDU
查看>>
Tomcat在Linux上的安装与配置
查看>>