使用LINQPad可以很方便的调试linq
以及lambda
表达式。其中自带了linq
以及F#
简单入门教程,LINQPad
不管你喜不喜欢,反正我喜欢了,呵呵。LINQPad
很精简,只有一个exe
文件,可以从http://www.linqpad.net下载到。不扯淡了,简单介绍下这个工具,展示下LINQPad
的魅力,真的很不错。
先看下如何连接数据库,运行LINQPad按下图进行操作,
点击next
,弹出如下界面,
点击OK后的界面如下,
下面就可以对具体表进行linq
操作了,如图
而后就可以在右侧的编辑窗口编写代码了,
点击不同的选项将会出现类似如下界面,
用linqPad帮助你快速学习LINQ
在这里我向大家推荐的一个具是LinqPad
有了这个工具并熟练使用就可以很快学习并掌握linq
linqPad下载地址:http://www.linqpad.net/
它也自带了很多例子方便大家查询,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
MyDataDemo
go
use MyDataDemo
go
drop table Student
create 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 Students
join cla in Classes
on stu.Class_Id equals cla.Class_Id
into MyJoin
from 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 Students
join cla in Classes
on stu.Class_Id equals cla.Class_Id
select 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
}
)
就讲到这里大家可以多学习一下这个工具