【极客营】LINQ进阶篇—LINQ To SQL

系列课程视频地址:https://ke.qq.com/course/267924?flowToken=1006068

LINQ To SQL通过LINQ对象模型直接与数据库进行数据交互,比如查询、修改等操作。

在LINQ To DataSet中,只是在DataSet层次对数据提供LINQ查询支持,可以说LINQ和ADO.Net是一种合作关系,然而,在LINQ To SQL中,将LINQ和ADO.Net集成得更加紧密,它将关系数据库模型映射到开发人员所有的编程语言(如C#等)所表示的对象模型。

LINQ To SQL是ADO.Net系列技术的一部分,它基于由ADO.Net提供程序模型提供的服务,因此开发人员可以将LINQ To SQL与现在的ADO.Net应用程序混合使用。

LINQ To SQL架构在ADO.Net之上。它通过ADO.Net进行数据库操作,同时通过LINQ To SQL提供程序实现对象模型和关系数据库模型之间的转换,另外,对象关系模型是LINQ To SQL的核心部分,它提供数据库和对象模型之间的映射关系。

LINQ To SQL查询所用的语法与在LINQ中使用的语法相同,不同的是,查询中引用的对象被映射到数据库中的元素,在应用程序执行期间,通过LINQ To SQL来请求LINQ查询执行。LINQ To SQL支持程序随后将LINQ查询转换成等效的SQL命令,并委托ADO.Net提供程序执行数据库操作。ADO.Net提供程序将查询结果作为DataReader/DataSet返回,然后LINQ To SQL提供程序将ADO.Net结果转换成用户对象IQueryable集合,并对IQueryable集合进行查询,返回查询结果。

 

IQueryable<T>接口是LINQ To SQL中使用到的主要接口,它从IEnumerable<T>继承而来,表示一个可以查询的数据集合,可以通过LINQ对其进行查询,IQueryable<T>成员的用法与IEnumerable<T>相同。

1、对象模型原理及O/R设计器构成

在LINQ To SQL中,将编程语言表示的对象模型映射到关系数据库的数据模型,开发人员按照对象模型来执行对数据的操作,从而实现对数据库的操作,数据库访问变得更加快捷高效。

在LINQ To SQL中,开发人员不用向数据库发出SQL命令(例如:select、insert、update、delete等),而是在对象模型中直接更改值或执行方法,当开发人员能过对象模型执行操作时,LINQ To SQL将请求转换成正确的SQL命令,然后将这些命令发送到数据库,得到返回数据库服务器的操作结果后,再将这些结果传递到对象模型。

LINQ To SQL对象模型原理图如下:

 

Join操作 适用场景:在我们表关系中有一对一关系,一对多关系,多对多关系等。对各个表之间的关系,就用这些实现对多个表的操作。 说明:在Join操作中,分别为Join(Join查询), SelectMany(Select一对多选择)和GroupJoin(分组Join查询)。 该扩展方法对两个序列中键匹配的元素进行inner join操作 SelectMany 说明:我们在写查询语句时,如果被翻译成SelectMany需要满足2个条件。1:查询语句中没有join和into,2:必须出现EntitySet。在我们表关系中有一对一关系,一对多关系,多对多关系等,下面分别介绍一下。 1.一对多关系(1 to Many): var q = from c in db.Customers from o in c.Orders where c.City == "London" select o; 语句描述:Customers与Orders是一对多关系。即Orders在Customers中以EntitySet形式出现。所以第二个 from是从c.Orders而不是db.Orders里进行筛选。这个例子在From子句中使用外键导航选择伦敦客户的所有订单。 var q = from p in db.Products where p.Supplier.Country == "USA" && p.UnitsInStock == 0 select p; 语句描述:这一句使用了p.Supplier.Country条件,间接关联了Supplier表。这个例子在Where子句中使用外键导航筛选其供应商在美国且缺货的产品。生成SQL语句为: SELECT [t0].[ProductID], [t0].[ProductName], [t0].[SupplierID], [t0].[CategoryID],[t0].[QuantityPerUnit],[t0].[UnitPrice], [t0].[UnitsInStock], [t0].[UnitsOnOrder],[t0].[ReorderLevel], [t0].[Discontinued] FROM [dbo].[Products] AS [t0] LEFT OUTER JOIN [dbo].[Suppliers] AS [t1] ON [t1].[SupplierID] = [t0].[SupplierID] WHERE ([t1].[Country] = @p0) AND ([t0].[UnitsInStock] = @p1) -- @p0: Input NVarChar (Size = 3; Prec = 0; Scale = 0) [USA] -- @p1: Input Int (Size = 0; Prec = 0; Scale = 0) [0] 2.多对多关系(Many to Many): var q = from e in db.Employees from et in e.EmployeeTerritories where e.City == "Seattle" select new { e.FirstName, e.LastName, et.Territory.TerritoryDescription }; 说明:多对多关系一般会涉及三个表(如果有一个表是自关联的,那有可能只有2个表)。这一句语句涉及Employees, EmployeeTerritories, Territories三个表。它们的关系是1:M:1。Employees和Territories没有很明确的关系。 LINQ to SQL语句之Join和Order By部分代码 语句描述:这个例子在From子句中使用外键导航筛选在西雅图的雇员,同时列出其所在地区。这条生成SQL语句为: SELECT [t0].[FirstName], [t0].[LastName], [t2].[TerritoryDescription] FROM [dbo].[Employees] AS [t0] CROSS JOIN [dbo].[EmployeeTerritories] AS [t1] INNER JOIN [dbo].[Territories] AS [t2] ON [t2].[TerritoryID] = [t1].[TerritoryID] WHERE ([t0].[City] = @p0) AND ([t1].[EmployeeID] = [t0].[EmployeeID]) -- @p0: Input NVarChar (Size = 7; Prec = 0; Scale = 0) [Seattle] 。。。。。。。。。。。。。。。。。。。。。。。。。。。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值