系列课程视频地址: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对象模型原理图如下: