添加记录 nlog 日期获取错误无效月份

add record nlog date get error invalid month

我使用 nlog dll 写入数据库 - oracle with entity frameWork in the line :

logger.Log(logLevel, "try");  

我在 NLog 的日志中收到以下错误:

Warn DatabaseTarget: Parameter: 'TIME_STAMP' - Failed to assign DbType=OracleDbType.Date Error DatabaseTarget(Name=WS_TRACE): Error when writing to database. Exception: System.Data.OracleClient.OracleException (0x80131938): ORA-01843: Invalid month

代码为:

 SetPropGDC(LogEntity);
 NLog.LogLevel logLevel = SetLogLevel(Level.Debug);
 logger.Log(logLevel, "try");
 ClearGDC();

 private void SetPropGDC(LogEntity LogEntity)
    {
        GlobalDiagnosticsContext.Set(processId, LogEntity.PROCESS_ID.ToString());
        GlobalDiagnosticsContext.Set("TIME_STAMP", DateTime.Now);
        GlobalDiagnosticsContext.Set(customerId, LogEntity.CUSTOMER_ID.ToString());

    }
  <targets>
    <target name="TRACEDatabase" type="DataBase"  keepConnection="false" 
             dbProvider="Oracle.ManagedDataAccess.Client" connectionString="${gdc:connectionString}"
             commandText="insert into TLOG_SITE_GENERAL_TRACE( PROCESS_ID,TIME_STAMP,CUSTOMER_ID)
                           values(:PROCESS_ID,:TIME_STAMP,:CUSTOMER_ID)">
      <parameter name="PROCESS_ID" layout="${gdc:PROCESS_ID}" />
      <parameter name="TIME_STAMP" layout="${gdc:TIME_STAMP}" dbType="OracleDbType.Date" />
      <parameter name="CUSTOMER_ID" layout="${gdc:CUSTOMER_ID}" />

    </target>
  </targets>

我尝试在 Web.config 中更改行:

<parameter name="TIME_STAMP" layout="${gdc:TIME_STAMP}" dbType="OracleDbType.Date" />

至:

<parameter name="TIME_STAMP" layout="${longDate}" dbType="OracleDbType.Date" />

我也遇到了同样的错误

首先,强烈推荐使用内置的布局渲染器。

比如${longdate},还有${processid}。这些都经过优化并且更易于使用。 你可以找到所有这些 here

请注意,使用全局上下文 (GDC) 在多线程程序中可能很危险。同样在单线程中,您可以 "leak" 一些上下文。

但我想真正的问题是您的 NLog 已过时。 NLog 4.6 中添加了 DbType 支持。

所以首先更新NLog(强烈推荐使用Nuget)。我在这里使用 NLog 4.6.3+,但建议更新到 NLog 4.7

那么对于代码我建议这样做:

logger.WithProperty("CustomerId", LogEntity.CUSTOMER_ID).Log(loglevel, "Message");

并这样配置:

<targets>
    <target name="TRACEDatabase" type="DataBase"  keepConnection="false" 
             dbProvider="Oracle.ManagedDataAccess.Client" connectionString="${gdc:connectionString}"
             commandText="insert into TLOG_SITE_GENERAL_TRACE( PROCESS_ID,TIME_STAMP,CUSTOMER_ID)
                           values(:PROCESS_ID,:TIME_STAMP,:CUSTOMER_ID)">
      <parameter name="PROCESS_ID" layout="${processid}" dbType="Int32" />
      <parameter name="TIME_STAMP" layout="${longdate}" dbType="Date" />
      <parameter name="CUSTOMER_ID" layout="${event-properties:CUSTOMER_ID}"  dbType="Int32"  />
    </target>
</targets>

另见 ${event-properties}

不需要使用特定的 OracleDbType,因此我选择只使用 "Date"(即 DbType.Date,参见 DbType

我找到了解决办法! 我更改了 dbType 参数:

 <parameter name="TIME_STAMP" layout="${gdc:TIME_STAMP}" dbType="OracleDbType.Date"  />

收件人:

 <parameter name="TIME_STAMP" layout="${gdc:TIME_STAMP}" dbType="DateTime" />

而且有效!