log4net
プロジェクトでエラーをログに記録するために使用します。メッセージを DB ( ) に記録したいSQL Server
ので、追加しましAdoNetAppender
たが機能しません (他のアペンダーは正常に機能し、接続文字列は正しいです)。何が間違っている可能性がありますか?
6951 次
2 に答える
4
必要最小限のサンプル プロジェクトを作成することにしました。これは機能します。おそらく、それを機能させてみてください。
空のコンソール アプリケーション プロジェクトを作成します。log4net への参照を追加します。C# コード:
using log4net;
[assembly: log4net.Config.XmlConfigurator(Watch = true)]
namespace Litter
{
class Program
{
static void Main()
{
LogManager.GetLogger("default").Info("Hello, World!");
}
}
}
構成ファイル:
<?xml version="1.0" encoding="utf-8" ?> <configuration> <configSections> <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/> </configSections> <startup> <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" /> </startup> <log4net> <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=localhost\sqlexpress;initial catalog=Litter;integrated security=True;"/> <commandText value="INSERT INTO Logs ([Message]) VALUES (@message)"/> <parameter> <parameterName value="@message"/> <dbType value="String"/> <size value="2000"/> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%message"/> </layout> </parameter> </appender> <root> <level value="DEBUG"/> <appender-ref ref="AdoNetAppender"/> </root> </log4net> </configuration>
データベース テーブル:
CREATE TABLE [dbo].[Logs]([Message] [nvarchar](2000) NOT NULL) GO
それはそれが得られるのと同じくらい簡単です。あなたがこれを機能させることができれば、私はあなたのアプリの AdoNetAppender 構成を非常に詳しく調べ始めます。
于 2013-08-15T18:03:16.153 に答える
0
皆さん、ありがとうございました。問題はDBにありました。RowGuid
プロパティをtrueに設定するだけです。
于 2013-08-16T05:01:28.800 に答える