- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的业务对象存储在两个数据存储中。对象的一部分存储在 Azure 表存储中,另一部分存储在 Azure SQL 中。基本上 SQL 部分用于查询,而表存储用于占用大量空间的属性。
大多数时候,只使用对象的 SQL 部分(在 SQL 查询中)。只有当有人明确要求该对象时,才需要表存储属性。我想要实现的是一种设计,它将隐藏业务对象背后有两个数据源的事实,延迟加载存储表属性(因为在执行 SQL 查询时不需要它们)并且仍然使代码可测试。
我当前的设计有一些由工作单元创建的 POCO。我不想创建两个 POCO,一个用于表存储,一个用于 SQL,所以我在考虑以下设计:
//Make the properties virtual
public class Customer
{
public virtual string Name {get;set;} //Stored in SQL
public virtual string Age {get;set;} //Stored in SQL
public virtual string Details {get;set;} // This prop is stored in Table Storage
}
//Create a derived internal POCO that can notify when a property is asked
internal class CustomerWithMultipleStorage
{
public event EventHandler OnDetailsGet;
public override string Details
{
get { if (OnDetailsGet!=null) OnDetailsGet( ... ); /* rest of the code */ }
set { /* code */ }
}
}
我所有的数据层代码都将使用 CustomerWithMultipleStorage
,而 DL 之外的所有“外部”代码都将使用 Customer
,并且不会公开事件。现在,当工作单元返回一个 Customer
时,它将只加载 SQL 属性并订阅 Get 事件。如果使用 Customer 的人需要其余属性,将触发该事件并加载 Table Storage 属性。
你觉得这个设计怎么样?这是正确的方法吗?您知道执行此操作的更好方法吗?
最佳答案
您可以使用Lazy<T>
依赖注入(inject)。请注意,这只是为了给您一些想法。
internal class CustomerWithMultipleStorage : Customer
{
private readonly ISqlDataLayer _sqlDataLayer;
private readonly ITableStorageDataLayer _tableStorageDataLayer;
private readonly Lazy<string> _details;
private string _detailsValue;
public CustomerWithMultipleStorage(ISqlDataLayer sqlDataLayer, ITableStorageDataLayer tableStorageDataLayer)
{
_sqlDataLayer = sqlDataLayer;
_tableStorageDataLayer = tableStorageDataLayer;
_details = new Lazy<string>(() => return (string)_tableStorageDataLayer.GetValue<Customer>(this, "Details"));
}
public override string Details
{
get
{
return (_detailsValue ?? (_detailsValue = _details.Value));
}
set
{
_detailsValue = value;
_tableStorageDataLayer.SetValue<Customer>(this, _detailsValue);
}
}
}
public interface ITableStorageDataLayer
{
object GetValue<T>(T item, [CallerMemberName] string property = "");
void SetValue<T>(T item, object value, [CallerMemberName] string property = "");
}
您也可以只为每个对象使用一个带有映射数据的数据层(稍后我将提供示例)。
关于c# - 具有延迟加载和多个数据源的 UnitOfWork,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14735086/
我关注了this tutorial . 我已经到了使用 _unitOfWork.XYZRepository.Get() 调用存储库的阶段,现在更进一步,我想为我的 UnitOfWork 类编写一个接口
我的业务对象存储在两个数据存储中。对象的一部分存储在 Azure 表存储中,另一部分存储在 Azure SQL 中。基本上 SQL 部分用于查询,而表存储用于占用大量空间的属性。 大多数时候,只使用对
显然(而且很有可能)我当前的 UnitOfWork 实现存在缺陷,因为我在同时进行多个调用时出现连接错误。 异常: The underlying provider failed on Open. 内部
我目前已经做了一个 UnitOfWork 实现,它包装了数据库连接和事务。 using (var uow = UnitOfWorkFactory.Create()) { // do db op
在 DDD 模式中,工作单元应该与存储库耦合吗?我见过几个不同的例子,包括一个实现工作单元接口(interface)的存储库,一个实现工作单元本身行为的存储库,以及一个具有代表工作单元的属性的存储库,
我有一个像这样的特定和通用存储库: 通用存储库: public class Repository : IRepository where TEntity : class { protected
我正在使用以下 UnitOfWork 类,以便通过使用泛型为我的实体获取存储库。 public class UnitOfWork : IUnitOfWork { private readonly
我认为这是一个常见问题,但经过一番搜索后我找不到任何相关内容。 我遇到的问题是,当使用 @UnitOfWork 注释我的资源方法并在我的资源方法内部时,我得到了一个 No Hibernate Sess
我正在为我们需要构建的小型应用构建单元测试。 我已经实现了存储库/工作单元模式。我的经理类实现了工作单元模式。 对于给定的接口(interface): public interface IUserMa
对 FluentNHibernate 很陌生,但我也对这个领域感到兴奋。我最近开始使用上述方法开发新的 DAL,并且一直在阅读存储库模式。我喜欢此模式采用的通用形式,并希望将此模式与 UnitOfWo
我有以下类(class): public FooDAO extends AbstractDAO { // Dropwizard DAO @Inject FooDAO(SessionFactory
我有这些类(class): public static class UnitOfWorkSS { public static IUnitOfWork Begin() { return
我正在尝试实现一个通用的存储库模式。我找到了这个网站,我认为它解释得很好。 http://www.tugberkugurlu.com/archive/generic-repository-patter
如果我实现一些简单的 OR/M 工具,我应该把恒等映射放在哪里?显然,每个 Repository 都应该有权访问自己的标识映射,以便它可以注册加载的对象(或者 DataMapper 是在 Identi
互联网上到处都是关于UnitOfWork的信息图案;甚至 SO 也不异常(exception)。 我还是不明白。据我了解 UnitOfWork = Transaction in DB .仅此而已;不多
我已经实现了我的 UnitOfWork,以便它保留对所有存储库的引用。 public interface IUnitOfWork { void Commit(); void RollBac
当使用 Rhino Commons UnitOfWork(在 ASP-MVC 的 UnitOfWorkApplication 中)时,我喜欢使用 Rhino Repository 静态类来保存这样的实
我有一个 Doctrine 事件监听器,用于监听 onFlush 事件。我使用它在保存时更新实体上的电子标签。 我需要访问计划删除的实体,以便我可以访问它们的关联对象,但是: 我使用的是软删除过滤器,
我在网上看到了很多关于 UnitOfWork 和 Repo 模式的信息,但仍然不清楚为什么以及何时使用——这让我有些困惑。 考虑到我可以通过使用 DI 通过使用 IoC 来测试我的存储库,如本文 Wh
我在后台任务方法(由 Quartz 操作)中使用 UnitOfWork,在 hibernate 之上使用 Guice-persist。后台任务调用一个服务,它需要在它的任务中间提交当前事务——然后继续
我是一名优秀的程序员,十分优秀!