- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
使用 OR 映射器有意义吗?
我将这个问题放在 stack overflow 上,因为这是我所知道的最好的地方,可以找到愿意提供帮助和意见的聪明的开发人员。
我的推理如下:
1.) SQL 属于哪里?
a.) 在我从事的每个专业项目中,数据的安全性一直是关键要求。存储过程为控制访问和审核提供了一个天然的网关。
b.) 生产中的应用程序问题通常可以在表和存储过程之间解决,而无需推出新版本。
2.) 如何控制生成的 SQL?我相信解析树可以生成高效的 SQL。我在 SQL-Server 和 Oracle 中优化 SQL 有相当多的经验,但如果我再也不必这样做,就不会觉得受骗了。 :)
3.) 如果我从存储过程中获取数据,那么使用 OR-Mapper 有什么意义?
我已经将存储库模式与自主开发的通用数据访问层一起使用。如果需要缓存一个集合,我就缓存它。我也有在小型 CRUD 应用程序上使用 EF 的经验,以及帮助调整遇到性能问题的 NHibernate 应用程序的经验。所以我有点偏,但愿意学习。
在过去的几年里,我们一直听到许多受人尊敬的开发人员提倡使用特定的 OR-Mappers(Entity-Framework、NHibernate 等)。
谁能告诉我为什么有人应该转向 ORM 进行大型项目的主流开发?
编辑:http://www.codinghorror.com/blog/2006/06/object-relational-mapping-is-the-vietnam-of-computer-science.html似乎对这个主题有强烈的讨论,但它已经过时了。
另一个编辑:每个人似乎都同意存储过程将用于重型企业应用程序,因为它们具有性能优势并且能够将编程逻辑添加到更接近数据的位置。
我发现支持 OR 映射器的最有力论据是开发人员的生产力。
我怀疑 ORM 运动的一个重要插入力是开发人员倾向于保持不可知的持久性(不关心数据是在内存中 [除非缓存] 还是在数据库中)。
ORM 似乎是本地和小型 Web 应用程序的出色省时工具。
也许我看到的最好的建议来自 client09:使用 ORM 设置,但对数据库密集型的东西使用存储过程(当 ORM 似乎不足时也称为存储过程)。
最佳答案
多年来我一直是专业 SP,并认为这是进行 DB 开发的唯一正确方法,但我完成的最后 3-4 个项目是在 EF4.0 中完成的,没有 SP,并且改进了我的工作效率确实令人惊叹 - 我现在可以用几行代码来完成以前需要一天才能完成的工作。
我仍然认为 SP 对于某些事情很重要(有时您可以通过精心选择的 SP 显着提高性能),但对于一般的 CRUD 操作,我无法想象回头。
所以对我来说简短的回答是,开发人员的工作效率是使用 ORM 的原因 - 一旦你克服了学习曲线。
关于database - 使用 OR-Mapper 有意义吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5343687/
我有一张 table People (First_Name, Last_Name)。此表包含与示例中一样重复的记录(并非所有行都重复): First_Name Last_Name John
我用 Java 编写过很多程序,之前也涉足过 C++。我在各种 C++ 书籍中阅读了有关指针的内容,并完成了书籍中的各种示例。 我了解指针的基础知识,但有一件事我一直不清楚。指针在现实世界中的应用是什
线 .Mappings(m => m.FluentMappings.AddFromAssemblyOf() 它有什么作用?它会在派生自 ClassMap 的 Product 类的程序集中查找任
我有用于打印数字的自定义打印功能。我制作了一个 ASCII 版本和一个 UTF-16LE 版本。 UTF-16LE 版本对 0-9 使用全角代码/字符,对十六进制使用 A-F。在调试我的函数时,我注意
这是我的代码片段: float ab(float); 以后 if(ab(temp)
我在一个项目文件中包含以下代码: //begin of the file ((window) => { 'use strict'; class View extends GSM.Event
我一直在到处寻找关于 ? 用法的正确解释。和 *。我注意到我可以使用以下方法拒绝所有用户的访问: 如果我想允许某个组,我应该在其上方添加下一行: 但是当我看到人们使用 ? 时,我开始忘记什么意思,
我正在关注 melon js tutorial .这是在我的 HUD.js 文件的顶部。 game.HUD = game.HUD || {} 我以前在其他例子中见过这个。 namespace.some
我正在处理一个包含数千行代码的文件。我正在第 700 行实现一个算法。我经常不得不离开这些行来检查文件中的其他方法。 导航回到我实际编码的地方通常很痛苦。如果我可以在第 700 行设置一个航路点并为其
我遇到了这段代码 do { if (higherQuality && w > targetWidth) { w /= 2; if (w &
uint8_t * const LCDMem = (uint8_t *) &LCDM3; 此代码在 msp430fg4618 培训套件中用于 lcd 配置。谁能解释一下上述代码的含义? 它允许使用 a
上下文 阅读一些内核代码。 问题 我不明白这行是什么意思 *(void **) &(int[2]){0,PAGE_SIZE}; 还有更多,这是什么意思 {0,PAGE_SIZE} 对我来说,它看起来不
我正在查看 Underscore.js 的源代码库,专门用于 map方法(该页面第 85 行左右,并复制到此处): _.map = function(obj, iterator, context)
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
我是一名优秀的程序员,十分优秀!