有志者、事竟成,破釜沉舟,百百二秦关终属楚;苦心人、天不负,卧薪尝胆,三千越甲可吞吴。

拂晓犬吠

学习中遇到困难是很正常的事情,不要苦恼,不要气馁,恰恰相反,应该兴奋,因为又学到知识了,需要不断提高自己应对问题和解决问题的能力和信心。

开始写博客,学习Linq(3)

为什么需要Linq?(摘自原文)

读者会发现LINQ着眼于解决编程语言和数据库之间广发存在的不统一问题。

1.常见的问题,使用.NET Framework Class Library(FCL)提供了ADO.NET,开发人员必须显式地操作数据库中的表、记录、列,而当下流行的C#语言却都是面向对象的。

为了解决上面说的ADO.NET的问题,当然可以使用某些对象/关系映射工具,但这些工具也不是完美的,存在着自身的限制。例如,用来访问数据库的工具一般没法处理其他数据源,比如XML。

并且有一件事情只用微软能够做到,而第三方对象/关系映射工具生厂商无法实现,那就是将数据访问以及查询功能集成至语言本身中。

所以引入LINQ的动机主要有两个:一是微软尚没有一套数据映射解决方案;二是借助LINQ能够将查询集成至开发语言中。

LINQ的设计目的在于,开发人员可以在其熟悉的语言中使用统一的查询访问任何数据源。

额,我感觉这部分于前面部分有重复呢,都是使用Linq可以解决的问题。

2.解决理念上的失调

这部分,文字真多了,我看了好久,都有点不耐烦了。具体值得什么意思呢?

阻抗失调,就是面向对象、关系型数据库以及xml,表现数据时并不能很好的转换(个人理解的);

对象/关系映射,首先基础数据类型就不同,其次是理论来源于不同的数据模型,比例的是关系型数据库和面向对象的模型,然后又说编程模型也不同,最后提到了封装也是不同的。

总而言之,就是关系型数据库和面向对象的类层次结构之间存在着差异。

但是,我们希望将对象模型映射到关系型数据库中,一般来说,连接面向对象语言和关系型数据库的一个解决方案是使用对象/关系映射,简而言之,我们为对象/关系映射程序提供类、数据库以及映射的配置,随后映射程序将自动完成余下的工作。比如生成SQL语句、从数据库中获取数据并填充至对象中,以及将对象持久化到数据库中等。

当然,没有那种解决方案是完美的,且对象/关系映射程序仍有改进的空间。

总结下,无法完美的转换,可以使用对象/关系或者xml映射 程序工具来解决转换的问题。当然,也只是书中抛砖引玉,最终的解决方案就是Linq喽。

“阻抗失调”让我们不得不在两边中选择其一作为“主要”的一边。在Linq中微软公司选择了编程语言作为主要的一边,因为修改C#和VB.NET要比修改SQL或XML容易得多。LINQ的主要理念是将数据查询和维护的工作紧密集成至编程语言中。

LINQ打通了对象、数据库和XML之间的很多限制,允许开发人员基于相同的语言集成特性操作3种不同领域中的数据。

这样,我有个问题,LINQ是不是包含了对象/关系或xml映射 工具的功能了,我之前是分不清Linq和EF的。

posted @ 2017-05-14 15:38  ID拂晓犬吠  阅读(149)  评论(0编辑  收藏  举报