我们有一个工具可以为我们的 Oracle 数据库中的存储过程生成映射代码。我将尝试尽可能抽象地解释它,没有任何噪音,因此一切都被大大简化了。
假设这是我们生成的代码的一部分:
public interface IDbMethodCaller
{
IEnumerable<object> ExecuteMethodCall(string methodName, IEnumerable<string> parameters);
}
public class GeneratedSchemaContext
{
private readonly IDbMethodCaller _dbMethodCaller;
public GeneratedSchemaContext(IDbMethodCaller dbMethodCaller)
{
_dbMethodCaller = dbMethodCaller;
}
public IEnumerable<object> ExecuteSampleProcedure()
{
return _dbMethodCaller.ExecuteMethodCall("sample_procedure", new List<string>());
}
}
我们通常有一个用于数据访问目的的标准类:
public class OracleDataContext
{
public IEnumerable<object> ExecuteMethodCall(string methodName, IEnumerable<string> parameters)
{
Debug.WriteLine("OracleDataContext.ExecuteMethodCall");
return new List<object>();
}
}
现在我想将上面的 DataContext 用于GeneratedSchemaContext
. 那么我该怎么做呢?该类本身无法实现 IDbMethodCaller,因为在其他项目中它不知道接口(生成代码的一部分)。
我考虑了适配器模式并对其进行了一些更改:
public class OracleDataContextAdapter : OracleDataContext, IDbMethodCaller
{
public new IEnumerable<object> ExecuteMethodCall(string methodName, IEnumerable<string> parameters)
{
Debug.WriteLine("OracleDataContextAdapter.ExecuteMethodCall");
return base.ExecuteMethodCall(methodName, parameters);
}
}
所以现在我可以执行以下操作:
var db = new GeneratedSchemaContext(new OracleDataContextAdapter());
var result = db.ExecuteSampleProcedure();
- 有没有更优雅的方式来完成这项任务?您如何看待解决方案?
- 这仍然是适配器模式还是我误解了它?