1

我们有一个工具可以为我们的 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();
  1. 有没有更优雅的方式来完成这项任务?您如何看待解决方案?
  2. 这仍然是适配器模式还是我误解了它?
4

1 回答 1

0

更干净、更优雅的解决方案是使用带有 OracleDataContext 的构造函数注入的实现 IDbMethodCaller。这样你就不需要使用 new 方法修饰符:

public class OracleDataContextAdapter : IDbMethodCaller
{


    private OracleDataContext dataContext;

    public OracleDataContextAdapter(OracleDataContext oracleContext)
    {

       this.dataContext =  oracleContext;  
    }

    public new IEnumerable<object> ExecuteMethodCall(string methodName, IEnumerable<string> parameters)
    {
        Debug.WriteLine("OracleDataContextAdapter.ExecuteMethodCall");

        return this.dataContext.ExecuteMethodCall(methodName, parameters);
    }
}
于 2013-09-05T13:15:12.093 回答