- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
由于 Mark Seemann 的这句话,我可能正在执行不可能的任务:
If you have a specific ORM in mind, then be explicit about it. Don't hide it behind an interface. It creates the illusion that you can replace one implementation with another. In practice, that's impossible.
但我想要完成的是通过更改我在启动时的依赖项来使用 MongoDb 驱动程序切换我的 Entity Framework ORM。
但我一直遇到一些问题,即我没有提供足够的灵 active ,或者我的 MongoDb 实现中有太多 new NotImplementedException();
。
我的接口(interface)当前结构如下所示:
public interface IReadEntities
{
IQueryable<TEntity> Query<TEntity>() where TEntity : Entity;
}
public interface IWriteEntities : IUnitOfWork, IReadEntities
{
TEntity Get<TEntity>(object firstKeyValue, params object[] otherKeyValues) where TEntity : Entity;
Task<TEntity> GetAsync<TEntity>(object firstKeyValue, params object[] otherKeyValues) where TEntity : Entity;
IQueryable<TEntity> Get<TEntity>() where TEntity : Entity;
void Create<TEntity>(TEntity entity) where TEntity : Entity;
void Delete<TEntity>(TEntity entity) where TEntity : Entity;
void Update<TEntity>(TEntity entity) where TEntity : Entity;
}
public interface IUnitOfWork
{
int SaveChanges();
Task<int> SaveChangesAsync();
Task DiscardChangesAsync();
void DiscardChanges();
void Reload<TEntity>(TEntity entity) where TEntity : Entity;
Task ReloadAsync<TEntity>(TEntity entity) where TEntity : Entity;
}
但是通过这个实现,我已经无法完成“完整”的 MongoDb 实现,因为 MongoDb 不使用工作单元模式或两阶段提交。
然后我想将 IUnitOfWork
移动到 IWriteEntities
的扩展方法中,但后来我丢失了连接到实体上的 DbContext
框架实现,我不会在静态方法中使用服务定位器模式。
所以我最后的手段是问有没有我还没有尝试过的黄金之路?或者我应该简单地再创建两个接口(interface):
public interface IEntityFrameworkWriter : IWriteEntities, IUnitOfWork {} // Move IUnitOfWork out of IWriteEntities
public interface IMongoDbWriter : IWriteEntities {}
并在我的应用程序中使用这些。但话又说回来,这不是我计划的。感谢您提供任何反馈。
爆头
最佳答案
switch my Entity Framework ORM out with the MongoDb driver just by changing my dependencies on startup.
这比单纯的接口(interface)问题要深入得多。这将导致一场灾难性的哲学冲突。
MongoDB 应该与写入量较大、通常是非规范化的数据结构一起使用。您的索引、插入和工作程序很复杂,查询也很简单。架构必须经过精心设计以支持您需要的查询,而不是基于对象之间的关系。
经典的 SQL 方法是相反的:仅靠关系就足以产生良好的数据结构,架构很简单(尽管很大),没有用于最终一致性的工作人员,但是查询非常复杂,通常是因为属于一起的必须拆分到两个或三个表中。这就是为什么事务和工作单元是典型 SQL 环境中的关键,而 MongoDB 甚至不支持它们。
当然,我是在简化:这里有一个范围,您可以将 MongoDB 和 RDBMS 都用作简单的键值存储;您可以在 SQL 中提出非规范化的数据结构,并且可以在 MongoDB 中保留大量关系。但是您的 MongoDB 不会学习参照完整性或(分布式)事务,并且您的 SQL Server 不会放弃 SQL。
但是,您使用的抽象越多,它们获得的支持越广泛,您就越会将这些关键原则隐藏在臃肿的代码后面。我想一般可以这么说:一个足够抽象的接口(interface),任何技术都可以实现,但它会让用户感到沮丧。
关于c# - 对 MongoDb 和 Entity Framework 的抽象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28848416/
这个问题在这里已经有了答案: 10年前关闭。 Possible Duplicates: What is a framework? What does it do? Why do we need a f
我在按照 http://msdn.microsoft.com/en-us/data/jj591621.aspx 处的 Microsoft Data Developer 过程启用代码优先迁移时遇到了一些
我正在从 迁移项目 Entity Framework 4.3 在 .net 4 上运行到 Entity Framework 5 在 .net 4.5 上运行。在不做任何更改的情况下,当我尝试运行该项目
我正在使用 Entity Framework 6 并使用 EntityFramework Extended 来执行一些批量更新和批量删除。批量更新和批量删除工作正常,但我还需要知道更新/删除的实体(即
我在实体上添加了一个列,然后从模型中生成数据库或构建解决方案,然后收到一条消息,提示我刚添加的新列未映射。该数据库以前是从模型创建的,没有错误。 当我右键单击Entity并选择Table Mappin
每次我尝试运行我的代码时都会崩溃,因为我尝试启动函数以调用 SDK 的任何部分。 我在构建过程中包含了 FoundationSDK: 并且我在头文件中包含了对 SDK 的引用: 但是每次我运行这个,我
我以前能够毫无问题地提交我的申请。我的工作流程中唯一改变的部分是使用 Sourcetree。在对以下框架进行更新后,我在提交到 iOS App Store 时收到此警告。我还收到一封电子邮件,其中包含
假设我为 Asp.NET Web 应用程序安装了 .NET Framework 2.0、3.0、3.5。 我意识到 Framework 3.0 和 3.5 只是 Framework 2 的扩展,不太清
是否有 SaveChanges 事件在保存更改后但在更新更改跟踪器之前触发? 我正在使用 EF 6。 我需要在某个实体的状态发生变化时执行任务。 我已经覆盖了 SaveChanges 来设置它。我可以
我正在使用一个现有的数据库,并且我已经将其中一个表映射为一个实体(因为我需要映射一个外键)。 因此,在初始化此数据库时,我希望 EF 忽略此实体,因为它已经存在。 我该怎么做? 最佳答案 您应该使用
我有 3 个表需要与 Entity Framework 进行映射,但我不确定解决此问题的正确方法。这是我的 3 个实体: public class User { [Key] public
我首先使用 VS 2010 和 Entity Framework 代码(版本 6)。我有两个实体,每个实体都在自己的上下文中,我想在它们之间创建一对多关系。 上下文 1 具有以下实体: public
我知道 EF 在 CodePlex 上是开源的,但我没有看到当前发布的 5.0 版本的分支。我在哪里可以得到这个源代码? 最佳答案 没有。他们只开源了 post 5 版本。第一次签到可能足够接近,但再
我们目前有一个数据库很大的系统,存储过程既用于CUD又用于查询。数据集用于从 SP 查询中检索结果。 现在我们正在研究使用 Entity Framework 针对同一个数据库开发另一个项目。在查询数据
我有一个每 10 秒运行一次的 Windows 服务......每次运行时,它都会获取一些测试数据,对其进行修改并使用 EntityFramework 将其保存到数据库中。但是,在每一秒运行时,当我尝
我对在我们的场景中仅将 Entity Framework 与存储过程一起使用的合理性有疑问。 我们计划拥有一个 N 层架构,包括 UI、BusinessLayer (BLL)、DataAccessLa
当我使用 Entity Framework 时,我想在上下文中查询出一条记录并将其添加到具有相同架构的另一个上下文中,在查询出记录后,我将其从上下文中分离出来,但是相关实体都没有了,是吗?有什么办法解
我正在使用 Entity Framework 5 构建 ASP.Net MVC4 Web 应用程序。我必须使用现有的 sql server 数据库,但也想使用 Code First,所以我遵循了本教程
在 Entity Framework 4.0 中使用 T4 模板创建 POCO 会丢失什么?为什么使用 Entity Framework 4.0 时的默认行为不创建 POCO? 最佳答案 你会失去很多
我在网上使用 Repository Pattern 和 EF 看了很多例子。但他们都没有真正谈到与相关实体的合作。 就像说用户可以有多个地址。 IUserRepository User CreateU
我是一名优秀的程序员,十分优秀!