繁体   English   中英

C#dapper映射到接口

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM