2015-12-07 52 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>