首页 > 代码库 > 开始写博客,学习Linq(3)
开始写博客,学习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(3)