[英]C# dapper map to interface
我可以使用C#dapper做这样的事情:
IFoo bar = _dbConnection.Query<IFoo>("My query there");
现在我不能这样做,因为没有必要的默认无参数构造函数。
是否有一些技巧来尊重SOLID的神(特别是Liskov替换原则的精神)或者我应该保留它并将我的数据映射到IFoo而不是Foo?
我真的很担心尊重这些SOLID的东西,但仍然不知道我应该在哪里做,所以寻找这个具体情况的建议。
您需要实例化类的具体实现。 在内部,它必须创建一个新对象。 您无法创建接口的新实例:
var foo = new IFoo(); // This won't build!
您仍然可以将结果转换为接口,但是您需要从数据库构建具体类型。
IEnumerable<IFoo> foo = _dbConnection.Query<Foo>("My query there");
组织存储库的一种方法是使用私有类对象进行查询,但将结果公开为公共接口。
Pulbic模型:
namespace MyProject.Foo.Model
{
public interface IFoo
{
string Property1 { get; set; }
string Property2 { get; set; }
}
public interface IFooRepository
{
IEnumerbale<IFoo> GetFoos();
}
}
使用私有类查询实现:
namespace MyProject.Foo.Repositories
{
public class FooRepository: IFooRepository
{
private class Foo: IFoo
{
public string Property1 { get; set; }
public string Property2 { get; set; }
}
public IEnumerbale<IFoo> GetFoos()
{
IEnumerable<IFoo> foo = _dbConnection.Query<Foo>("My query there");
return foo;
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.