首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ORMLite / ServiceStack软删除

ORMLite / ServiceStack软删除
EN

Stack Overflow用户
提问于 2017-10-11 16:42:48
回答 1查看 179关注 0票数 1

好吧,我已经发过几次关于这个的文章了,现在还没有找到一个可行的解决方案。我看到了其他的例子/建议,并遵循了它们,但没有成功。我已经到了极限,希望能在这里弄清楚。最终,我试图实现在数据库中选择任何对象的能力,同时过滤“IsDeleted”标志。

我将ORMLite与ServiceStack结合使用。我使用的是存储库模式,ServiceStack也使用Funq。当我的AppHost启动时,我会在容器中注册我的DbConnectionFactory,以及存储库实例。连接工厂通过构造函数注入传递。

代码语言:javascript
复制
public override void Configure(Container container)
{
    <...>

    container.Register<IDbConnectionFactory>(new OrmLiteConnectionFactory(ConfigurationManager.ConnectionStrings["connstring"].ConnectionString, SqlServerDialect.Provider));
    container.Register<ICompanyRepository>(c => new Repositories.OrmLite.CompanyRepository(container.Resolve<IDbConnectionFactory>()));

    <...>
}

我的所有模型类都有一个公共基类/接口,其中包含我们的标准审计字段以及“IsDeleted”标志。这由一个名为“IAuditModel”的接口表示:

代码语言:javascript
复制
public interface IAuditModel
{
    int CreatedBy { get; set; }
    int ModifiedBy { get; set; }
    DateTime CreatedDateTime { get; set; }
    DateTime ModifiedDateTime { get; set; }
    bool IsModified { get; set; }
}

在我的存储库类中,我试图检索未标记为已删除的记录,但我试图避免在每个查询中指定这些记录。我尝试为基库类的构造函数中的类型创建一个特定的选择筛选器:

代码语言:javascript
复制
public class OrmLiteRepositoryBase : IRepositoryBase
{
    <...>

    protected readonly OrmLiteConnectionFactory olcf;

    public OrmLiteRepositoryBase(IDbConnectionFactory cf)
    {
        olcf = cf as OrmLiteConnectionFactory;

        SqlExpression<Vendor>.SelectFilter = q => q.Where(x => !x.IsDeleted);

        OrmLiteConfig.InsertFilter = (dbCmd, row) =>
        {
            <...>
        }

        OrmLiteConfig.UpdateFilter = (dbCmd, row) =>
        {
            <...>
        }

        <...>
    }
}

Vendor类通过基类实现IAuditModel。以上是我第一次尝试对特定类型进行过滤。然后,我尝试了下面的内容,下面是我在这里的堆栈溢出以及在github上的SoftDeleteUseCase中找到的建议:

代码语言:javascript
复制
OrmLiteConfig.SqlExpressionSelectFilter = (q) =>
{
    if(q.ModelDef.ModelType.HasInterface(typeof(IAuditModel))
    {
        a.Where<IAuditModel>(x => x.IsDeleted);
    }
}

我尝试将此选择筛选器包括在以下内容中:

  1. 在应用程序主机注册连接工厂之后。
  2. 在InsertFilter所在的存储库构造函数中。
  3. 在存储库方法本身中,打开DbConnection之后。

我最终将使用泛型方法在共享基类中进行查询,如下所示:

代码语言:javascript
复制
db.Select<T>();

没有工作,我得到所有的记录(包括那些标记为‘删除’)每次。有趣的是,如上面所示的存储库构造函数中所示的InsertFilter和UpdateFilter的工作与我所期望的一样。我不能为我的一生得到这个选择过滤器的工作。在进行'Select()‘调用之后调用'GetLastSql()’显示没有应用筛选器的迹象。有人,任何人,请帮我弄明白这一点。谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-10-11 21:23:34

软删除过滤器在其实现中将条件附加到SqlExpression,从而添加到只适用于使用SqlExpression的APIs。,例如:

代码语言:javascript
复制
var results = db.Select(db.From<Table>());
var result = db.Single(db.From<Table>().Where(x => x.Name == "foo"));
var result = db.Single(x => x.Name == "foo");
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46693526

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档