我很难找到一种干净的方式来实现我的分层。
这是我拥有的层(下层支持上层,通过继承或组合):
Business Logic Layer (BLL)
Datastore Layer (DSL)
Database Layer (DBL), Web-Service Buffer (WSB)
当 BLL 对象发出 get 请求 getRecords() 时,它又要求 DSL 完成它。
然后 DSL 决定天气是使用本地 DBL 还是使用 WSB(它与远程 Web 服务前端与“主”数据库通信)。
选项 1 - 组合(BLL 有一个 DSL,DSL 有一个 DBL)
我的问题是,由于 DSL 和 DBL 对象是在 BLL 中组成的,它们对包含 BLL 一无所知,那么他们应该如何进行包含 BLL 字段的特定 DB 查询?
选项 2 - 继承(BLL:DSL,DSL:DBL)
即使较低层现在可以通过公共/受保护的继承访问 BLL,但关于 DSL 和 DBL 如何准确知道要生成哪些特定查询字符串的问题仍然存在。我想 BLL 可以保留一组静态字符串,但这会产生双向依赖,我认为这是一个非常有缺陷的设计,会带来可怕的后果。
注意:每个 BLL 都有一个对应的表,它被序列化到/反序列化。
注意:我不想使用反射,并且想限制泛型的使用(除非绝对没有其他方法。我正在为我的 WSB 使用泛型,虽然我主要关心的是生成DSL 和 DBL 层中特定于 BLL 的查询字符串)。
注意:将会有许多不同的 BLL 对象将使用 DSL 和 DBL 层,而不仅仅是一个(否则这将是微不足道的)。
public class BL1
{
private DSL _dsLayer;
public getRecords()
{
// ...
_dsLayer.getRecords();
// ...
}
}
public class DSL
{
private DBL _dbLayer;
private WSB _wsBuffer;
public getRecords()
{
if(_dbLayer.getRecords() != null)
{
return records;
}
else
{
return _wsBuffer.getRecords();
}
}
}
public class DBL
{
private string _db = "file.db3";
public getRecords()
{
select ????? - how to know what fields to grab
}
}
感谢您花时间回答这个问题,非常感谢。