2015-12-07 49 views
0

我的问题是我的数据库日志记录不显示秒(默认格式似乎是“yyyy-MM-dd hh:mm:00”。 有什么方法可以更改这并获得至少一些与秒(毫秒将是一个加号)Log4Net AdoNetAppender - 格式化日志日期以获得秒数

这里是我的appender配置:?!

<appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender"> 
    <bufferSize value="1" /> 
    <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" /> 
    <connectionString value="data source=MyDB;initial catalog=LogSpace;integrated security=True;persist security info=True;Application Name=&quot;MyApp &quot;" /> 
    <commandText value="INSERT INTO Log ([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" /> 
    <parameter> 
    <parameterName value="@log_date" /> 
    <dbType value="DateTime" /> 
    <layout type="log4net.Layout.RawTimeStampLayout" /> 
    </parameter> 
    <parameter> 
    <parameterName value="@thread" /> 
    <dbType value="String" /> 
    <size value="255" /> 
    <layout type="log4net.Layout.PatternLayout"> 
     <conversionPattern value="%thread" /> 
    </layout> 
    </parameter> 
    <parameter> 
    <parameterName value="@log_level" /> 
    <dbType value="String" /> 
    <size value="50" /> 
    <layout type="log4net.Layout.PatternLayout"> 
     <conversionPattern value="%level" /> 
    </layout> 
    </parameter> 
    <parameter> 
    <parameterName value="@logger" /> 
    <dbType value="String" /> 
    <size value="255" /> 
    <layout type="log4net.Layout.PatternLayout"> 
     <conversionPattern value="%logger" /> 
    </layout> 
    </parameter> 
    <parameter> 
    <parameterName value="@message" /> 
    <dbType value="String" /> 
    <size value="4000" /> 
    <layout type="log4net.Layout.PatternLayout"> 
     <conversionPattern value="%message" /> 
    </layout> 
    </parameter> 
    <parameter> 
    <parameterName value="@exception" /> 
    <dbType value="String" /> 
    <size value="2000" /> 
    <layout type="log4net.Layout.ExceptionLayout" /> 
    </parameter> 
</appender> 

谢谢您的帮助

编辑:正如建议通过嬉皮士,我检查了我的数据库中的日期类型,这是smalldatetime。我把它改成datetime和现在我的日志如预期(以秒&毫秒)

+1

我有相同的配置,你必须和我看到秒〜2日志中的小数位数 - 因为它被记录到'datetime2(2)'列中。您的日期列是什么数据类型? – stuartd

+0

啊,干得好。事实上,我的日期列类型是“smalldatetime”。我改为“日期时间”,现在日期格式正确(包括秒)。 谢谢! :) – Glad

回答

0

变化@log_date参数是这样的:

  <parameter> 
      <parameterName value="@log_date"/> 
      <dbType value="DateTime"/> 
      <layout type="log4net.Layout.PatternLayout" 
       value="%date{yyyy'-'MM'-'dd HH':'mm':'ss'.'fff}"/> 
      </parameter>