log4net inserting (null) into custom column

2019-07-24 00:17发布

Added a custom column as suggested here. Things are working fine when ever I log something into this column using the code line

log4net.GlobalContext.Properties["CustomColumn"] = "Custom value";

But if I pass null instead as below

log4net.GlobalContext.Properties["CustomColumn"] = null;

this is logged as (null)(a string null included in brakets). This also happens if I do not log at all, like I comment the code as shown below.

//log4net.GlobalContext.Properties["CustomColumn"] = null;

So the question is, is there a way to make it actually null in the database, instead of a string - (null). I am using ms sql server 2008 r2

2条回答
贪生不怕死
2楼-- · 2019-07-24 00:37

I have modified the insert statement of the commandText value in Web.config file to

"INSERT INTO Log ([Date],[Thread],[Level],[Logger],[Message],[Exception],[BrowserCapabilities]) VALUES (@log_date, @thread, @log_level, 
        @logger, @message, @exception, CASE WHEN @BrowserCapabilities = '' OR @BrowserCapabilities = '(null)' THEN NULL ELSE @BrowserCapabilities END )" 

Now this works fine.

查看更多
祖国的老花朵
3楼-- · 2019-07-24 00:42

try this

log4net.GlobalContext.Properties["CustomColumn"] = DBNull.Value;
查看更多
登录 后发表回答