1.关于配置文件。
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="System.Configuration.IgnoreSectionHandler" />
</configSections>
<log4net>
<root>
<level value="ALL" />
<appender-ref ref="rollingFile" />
<appender-ref ref="ADONetAppender"/>
</root>
<logger name="Presin_log">
<level value="ALL" />
<appender-ref ref="PresinLoging" />
</logger>
<logger name="Oracle_DB">
<level value="ALL" />
<appender-ref ref="OracleDB" />
</logger>
<logger name="flowseting_log">
<level value="ALL" />
<appender-ref ref="flowsetingLoging" />
</logger>
<!--Presin日志-->
<appender name="PresinLoging" type="log4net.Appender.RollingFileAppender,log4net" >
<param name="File" value="Log\Presin\" />
<param name="AppendToFile" value="true" />
<param name="RollingStyle" value="Composite" />
<param name="DatePattern" value="yyyy-MM-dd.'.txt'" />
<param name="MaximumFileSize" value ="5MB"/>
<param name="StaticLogFileName" value="false" />
<layout type="log4net.Layout.PatternLayout,log4net">
<conversionPattern value="%date %-5level %newline %logger - %message%newline %newline" />
</layout>
</appender>
<appender name="OracleDB" type="log4net.Appender.AdoNetAppender,log4net" >
<bufferSize value="20"/>
<connectionType value="System.Data.OracleClient.OracleConnection, System.Data.OracleClient, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>
<connectionString value="Data Source=ORCl;User ID=sa;Password=sa;" />
<commandText value="INSERT INTO LogDetails (LogDate,loglevel,loglogger,LogMessage,logfunctionname,logbusinessname) VALUES (:log_date,:log_level,:logger,:message,:FunctionName,:BusinessName)" />
<parameter>
<parameterName value=":log_date" />
<dbType value="DateTime" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date{yyyy-MM-dd HH:mm:ss}" />
</layout>
</parameter>
<parameter>
<parameterName value=":log_level" />
<dbType value="String" />
<size value="200" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%p" />
</layout>
</parameter>
<parameter>
<parameterName value=":logger" />
<dbType value="String" />
<size value="200" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger" />
</layout>
</parameter>
<parameter>
<parameterName value=":message" />
<dbType value="String" />
<size value="2000" />
<layout type="MapgisEgovLog4_WriteLog.MyLayout">
<conversionPattern value="%property{Message}" />
</layout>
</parameter>
<parameter>
<parameterName value=":FunctionName" />
<dbType value="String" />
<size value="200" />
<layout type="MapgisEgovLog4_WriteLog.MyLayout">
<conversionPattern value="%property{FunctionName}" />
</layout>
</parameter>
<parameter>
<parameterName value=":BusinessName" />
<dbType value="String" />
<size value="200" />
<layout type="MapgisEgovLog4_WriteLog.MyLayout">
<conversionPattern value="%property{BusinessName}" />
</layout>
</parameter>
</appender>
<!--flowseting日志-->
<appender name="flowsetingLoging" type="log4net.Appender.RollingFileAppender,log4net" >
<param name="File" value="Log\flowseting\" />
<param name="AppendToFile" value="true" />
<param name="RollingStyle" value="Date" />
<param name="DatePattern" value="yyyyMMdd" />
<param name="StaticLogFileName" value="true" />
<layout type="log4net.Layout.PatternLayout,log4net">
<conversionPattern value="%date %-5level %newline %logger - %message%newline %newline" />
</layout>
</appender>
</log4net>
</configuration>
a.在配置文件中,root节点下需要增加<appender-ref ref="ADONetAppender"/>代表允许将日志插入数据库中。
<root>
<level value="ALL" />
<appender-ref ref="rollingFile" />
<appender-ref ref="ADONetAppender"/>
</root>
rollingFile是将日志写入文件中,在这里不做讨论。
ADONetAppender是将日志写入数据库中,然后log4Net会根据接下来的配置connectionType和connectionString判断插入何种数据库和哪个数据库
b.增加一个logname,方便进一步添加属性
<logger name="Oracle_DB">
<level value="ALL" />
<appender-ref ref="OracleDB" />
</logger>
c.进一步配置OracleDB
<appender name="OracleDB" type="log4net.Appender.AdoNetAppender,log4net" >
<bufferSize value="20"/>
<connectionType value="System.Data.OracleClient.OracleConnection, System.Data.OracleClient, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>
<connectionString value="Data Source=ORCl;User ID=sa;Password=sa;" />
<commandText value="INSERT INTO LogDetails (LogDate,loglevel,loglogger,LogMessage,logfunctionname,logbusinessname) VALUES (:log_date,:log_level,:logger,:message,:FunctionName,:BusinessName)" />
<parameter>
<parameterName value=":log_date" />
<dbType value="DateTime" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date{yyyy-MM-dd HH:mm:ss}" />
</layout>
</parameter>
<parameter>
<parameterName value=":log_level" />
<dbType value="String" />
<size value="200" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%p" />
</layout>
</parameter>
<parameter>
<parameterName value=":logger" />
<dbType value="String" />
<size value="200" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger" />
</layout>
</parameter>
<parameter>
<parameterName value=":message" />
<dbType value="String" />
<size value="2000" />
<layout type="MapgisEgovLog4_WriteLog.MyLayout">
<conversionPattern value="%property{Message}" />
</layout>
</parameter>
<parameter>
<parameterName value=":FunctionName" />
<dbType value="String" />
<size value="200" />
<layout type="MapgisEgovLog4_WriteLog.MyLayout">
<conversionPattern value="%property{FunctionName}" />
</layout>
</parameter>
<parameter>
<parameterName value=":BusinessName" />
<dbType value="String" />
<size value="200" />
<layout type="MapgisEgovLog4_WriteLog.MyLayout">
<conversionPattern value="%property{BusinessName}" />
</layout>
</parameter>
</appender>
其中需要注意的是:
(1).bufferSize,代表缓存的记录条数,设置为20,表示log4net会在有20条日志时调用数据库并插入。
(2).connectionType代表数据库类型,注意Version和PublicKeyToken一定要于自己系统调用的版本一致。oracle的2.0版本的System.Data.OracleClient一般是2.0.0.0和b77a5c561934e089
(3)commandText代表插入的语句,注意oracle的参数是:参数,而sqlserver是@参数,且此处一定要保证,sql语句正确,如数据库中无此表或表无此字段,log4Net都不会报错,但不会进行任何操作。
(4)通过parameter逐一将要插入数据库的参数进行赋值和格式化
如:日期格式化和赋值
<parameter>
<parameterName value=":log_date" />
<dbType value="DateTime" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date{yyyy-MM-dd HH:mm:ss}" />
</layout>
</parameter>
字符串默认格式化和赋值
      <parameter>
<parameterName value=":logger" />
<dbType value="String" />
<size value="200" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger" />
</layout>
</parameter>
log4Net提供给我们的字段有:
log_date,log_level,logger,message等,其余的字段需要我们自定义
自定义字段格式化和赋值
      <parameter>
<parameterName value=":FunctionName" />
<dbType value="String" />
<size value="200" />
<layout type="MapgisEgovLog4_WriteLog.MyLayout">
<conversionPattern value="%property{FunctionName}" />
</layout>
</parameter>
log4Net提供的字段,我们也可以通过自定义重载
      <parameter>
<parameterName value=":message" />
<dbType value="String" />
<size value="2000" />
<layout type="MapgisEgovLog4_WriteLog.MyLayout">
<conversionPattern value="%property{Message}" />
</layout>
</parameter>
注意:layout Type中填写的是og4net的格式化类以及其命名空间。
conversionPattern中是使用扩展的格式化类中注册的格式化方法。
 
扩展格式化需要一些后台代码支持
 
/// <summary>
/// 包含了所有的自定字段属性
/// </summary>
public class LogContent
{
public LogContent(string sFunctionName, string sLogMessasge,string sLogBusinessName)
{
FunctionName = sFunctionName;
Message = sLogMessasge;
BusinessName = sLogBusinessName;
} /// <summary>
/// 方法名称
/// </summary>
public string FunctionName { get; set; } /// <summary>
/// 日志描述信息
/// </summary>
public string Message { get; set; } /// <summary>
/// 业务名称
/// </summary>
public string BusinessName { get; set; }
} public class MyLayout : PatternLayout
{
public MyLayout()
{
this.AddConverter("property", typeof(LogInfoPatternConverter));
}
} public class LogInfoPatternConverter : PatternLayoutConverter
{ protected override void Convert(TextWriter writer, LoggingEvent loggingEvent)
{
if (Option != null)
{
WriteObject(writer, loggingEvent.Repository, LookupProperty(Option, loggingEvent));
}
else
{
WriteDictionary(writer, loggingEvent.Repository, loggingEvent.GetProperties());
}
}
/// <summary>
/// 通过反射获取传入的日志对象的某个属性的值
/// </summary>
/// <param name="property"></param>
/// <returns></returns> private object LookupProperty(string property, log4net.Core.LoggingEvent loggingEvent)
{
object propertyValue = string.Empty;
PropertyInfo propertyInfo = loggingEvent.MessageObject.GetType().GetProperty(property);
if (propertyInfo != null)
propertyValue = propertyInfo.GetValue(loggingEvent.MessageObject, null);
return propertyValue;
}
}
其中:
d.自定义字段的类
    public class LogContent
{
public LogContent(string sFunctionName, string sLogMessasge,string sLogBusinessName)
{
FunctionName = sFunctionName;
Message = sLogMessasge;
BusinessName = sLogBusinessName;
} /// <summary>
/// 方法名称
/// </summary>
public string FunctionName { get; set; } /// <summary>
/// 日志描述信息
/// </summary>
public string Message { get; set; } /// <summary>
/// 业务名称
/// </summary>
public string BusinessName { get; set; }
}
e.扩展log4net的格式化方法
public class MyLayout : PatternLayout
{
public MyLayout()
{
this.AddConverter("property", typeof(LogInfoPatternConverter));
}
}
f.通过反射的方法获取LogContent中定义的字段
public class LogInfoPatternConverter : PatternLayoutConverter
{ protected override void Convert(TextWriter writer, LoggingEvent loggingEvent)
{
if (Option != null)
{
WriteObject(writer, loggingEvent.Repository, LookupProperty(Option, loggingEvent));
}
else
{
WriteDictionary(writer, loggingEvent.Repository, loggingEvent.GetProperties());
}
}
/// <summary>
/// 通过反射获取传入的日志对象的某个属性的值
/// </summary>
/// <param name="property"></param>
/// <returns></returns> private object LookupProperty(string property, log4net.Core.LoggingEvent loggingEvent)
{
object propertyValue = string.Empty;
PropertyInfo propertyInfo = loggingEvent.MessageObject.GetType().GetProperty(property);
if (propertyInfo != null)
propertyValue = propertyInfo.GetValue(loggingEvent.MessageObject, null);
return propertyValue;
}
}

调用示例

log4net.Config.XmlConfigurator.ConfigureAndWatch(new FileInfo(strPath + "配置文件.xml"));
ILog log = LogManager.GetLogger("Oracle_DB");
log.Info(new LogContent("Button1_Click", "测试成功","测试"));

参考:

http://blog.csdn.net/kongwei521/article/details/52242319

 

关于使用Log4Net将日志插入oracle数据库中的更多相关文章

  1. .net core 中使用Log4net输出日志到Mysql数据库中

    .net core 中使用Log4net输出日志到数据库中去 1.使用Nuget安装log4net 和 mysql.data 2.设置log4net 的配置文件 log4net.config 可以设置 ...

  2. 知方可补不足~利用LogParser将IIS日志插入到数据库

    回到目录 LogParser是微软开发的一个日志分析工具,它是命令行格式的,我们通过这个工具,可以对日志文件进行操作,对于一个几百兆的log文件,使用记事本打开是件很残酷的事,所以,很多情况下,我们都 ...

  3. Oracle 数据库中日期时间的插入操作

    Oracle 中如何插入日期时间类型的数据,首先为了演示, 新建数据表如下 create table t( mydate date); 插入日期时间 SQL> insert into t val ...

  4. 向Oracle数据库中插入数据出错:ORA-01036 无效的变量名或数据

    向Oracle数据库中插入数据出错: 经过排查,因为Update数据时没有出错,所以OracleHelper没有问题: 看异常信息提示:无效的变量和数据,应该是SQL语句的问题,调试时所传的实例Use ...

  5. Oracle数据库中插入日期型数据(to_date的用法)(转载)

    往Oracle数据库中插入日期型数据(to_date的用法) INSERT  INTO  FLOOR  VALUES  ( to_date ( '2007-12-20 18:31:34' , 'YYY ...

  6. 利用LogParser将IIS日志插入到数据库

    利用LogParser将IIS日志插入到数据库 上面的博文是定制一个计划任务来将log日志定时的导入数据库      下面这篇博文是用cmd指令将日志导入到一张sql表中,是一次性操作   Log P ...

  7. SQL语句往Oracle数据库中插入日期型数据(to_date的用法)

    Oracle 在操作数据库上相比于其他的 T-sql 有微小的差别,但是在插入时间类型的数据是必须要注意他的 to_date 方法,具体的情况如下: --SQL语句往Oracle数据库中插入日期型数据 ...

  8. Oracle数据库中SYS、SYSTEM、DBSNMP、SYSMAN四用户的区别

    [转]   SYS.SYSTEM.DBSNMP. Oracle 数据库中 SYS.SYSTEM.DBSNMP.SYSMAN 四用户的区别 用户: SYS 用户: SYS,默认密码为 CHANGE_ON ...

  9. Oracle数据库中实现mysql数据库中auto-increment功能

    在Mysql数据库中,想要实现一条数据的自增一功能(即插入此数据时填写null即可,系统自动+1),可直接在所在列使用语句auto-increment. id int primary key auto ...

随机推荐

  1. CCF-201503-2-数字排序

    问题描述 试题编号: 201503-2 试题名称: 数字排序 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 给定n个整数,请统计出每个整数出现的次数,按出现次数从多到少的顺序 ...

  2. PHP获取路径或目录实现

    <?php /**  * PHP获取路径或目录实现  */    //魔术变量,获取当前文件的绝对路径 echo "__FILE__: ========> ".__FI ...

  3. phpcms的验证码替换 及 phpcms实现全站搜索功能

    在使用phpcms替换网页的时候,除了正常的替换栏目.内容页等,其他的什么验证码啦,提交表单了,搜索功能了,这些在替换的时候可能会对一些默认文件有一些小小 的改变 下面就是自己在失败中成功的过程,最后 ...

  4. NOIP2014无线网络发射器选址改编1

    问题描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129条东西向街道和129条南北向街道所形成的网格状,并且相邻的平 ...

  5. Swagger服务API治理详解

    swager2的简介 在App后端开发中经常需要对移动客户端(Android.iOS)提供RESTful API接口,在后期版本快速迭代的过程中,修改接口实现的时候都必须同步修改接口文档,而文档与代码 ...

  6. 约瑟夫问题 小孩报数问题poj3750

    小孩报数问题 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 15228   Accepted: 6778 Descripti ...

  7. EFCore2.0 Code First基本使用

    前言 在网上找EFCore Code First相关的文章,很多都是基于core 1.0版本的,觉得有必要自己实践下2.0.所以,撸起袖子干吧!~ 1.新建控制台项目(这里就不放图了) 2.打开程序包 ...

  8. Android中使用ContentProvider进行跨进程方法调用

    原文同一时候发表在我的博客 点我进入还能看到很多其它 需求背景 近期接到这样一个需求,须要和别的 App 进行联动交互,比方下载器 App 和桌面 App 进行联动.桌面的 App 能直接显示下载器 ...

  9. windows远程桌面连接的时候不显示本地盘符

    近期远程异地pc机部署项目,远程连上后不显示本地盘符,勾选驱动器也无效,试下例如以下方法 在远程主机的文件地址栏里面键入: \\tsclient\D 后面再加入上对应的盘符,你的盘符的名称是什么盘就加 ...

  10. 基于Gulp + Browserify构建es6环境下的自动化前端项目

    随着React.Angular2.Redux等前沿的前端框架越来越流行,使用webpack.gulp等工具构建前端自动化项目也随之变得越来越重要.鉴于目前业界普遍更流行使用webpack来构建es6( ...