【问题标题】:Logging of sql statements in OrmLite (ServiceStack)在 OrmLite (ServiceStack) 中记录 sql 语句
【发布时间】:2013-07-30 11:27:52
【问题描述】:

如何将 OrmLite 生成的 Sql 语句记录到 NLog 之类的 Logging 框架中的最佳方式是什么?我知道 DbConnection 上的 GetLastSql() 方法,但还有其他方法吗?

我们希望在数据层中使用 OrmLite,并有可能记录 Windows 窗体应用程序的所有生成的 sql,该应用程序有几年时间并且所有 sql 都写在 GUI 中。性能是一个问题,所以我们决定使用 OrmLite(无上下文方法)

【问题讨论】:

    标签: ormlite-servicestack


    【解决方案1】:

    您必须创建自己的 ProfiledDbConnection 类实现,将日志写入 NLog。现在,当您创建 OrmLiteConnectionFactory 类集连接过滤器的实例时,您可以这样做:

     var db = new OrmLiteConnectionFactory(
       "ConnectionString", true, 
       SqliteOrmLiteDialectProvider.Instance) {
       ConnectionFilter = x => new ProfiledDbConnection(x, Profiler.Current)
    };
    

    这里有 ProfiledDbConnection 的 src https://github.com/ServiceStack/ServiceStack/blob/master/src/ServiceStack/MiniProfiler/Data/ProfiledDbConnection.cs

    【讨论】:

    • 谢谢,但这对于仅记录 sql 看起来很复杂 - 我们在 DbConnection 周围使用通用包装器(某种通用存储库),它使用此处建议的 GetLastSql() 方法 - stackoverflow.com/questions/11530943/…
    • 我忘了第二种可能性(最简单的)。
    猜你喜欢
    • 1970-01-01
    • 2021-11-03
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-07-16
    • 1970-01-01
    • 2011-02-03
    • 1970-01-01
    相关资源
    最近更新 更多