1、首先创建日志数据库 
用的是MySQL 
CREATE TABLE `td_log` ( 
  `lid` int(11) NOT NULL AUTO_INCREMENT, 
  `lusername` varchar(20) DEFAULT NULL, 
  `lmessage` varchar(200) DEFAULT NULL, 
  `lstartdate` varchar(30) DEFAULT NULL, 
  `level` varchar(20) DEFAULT NULL, 
  PRIMARY KEY (`lid`) 
)

2、配置文件中的部分内容: 
log4j.rootLogger=info,jdbc 
#直接使用log4j包中的文件 
log4j.appender.jdbc=org.apache.log4j.jdbc.JDBCAppender 
#与数据库建立连接 
log4j.appender.jdbc.URL=jdbc:mysql://localhost:3306/test 
log4j.appender.jdbc.driver=com.mysql.jdbc.Driver 
log4j.appender.jdbc.user=root 
log4j.appender.jdbc.password=admin 
log4j.appender.jdbc.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %5p %t %c{2}:%L - %m%n

#指定要插入数据库的格式,与数据库字段对应,与一般SQL区别不大,只是加上了log4j的一些配置参数而已。 
log4j.appender.jdbc.sql=insert into td_log(lusername, lstartdate, level, lmessage) values ('%X{lusername}','%d{yyyy-MM-dd HH:mm:ss}','%p','%m')

3、日志工具类源码如下 
/** 
* 系统日志辅助类 
* @author 
* @date  */ 
public class LogUtil{

/** 
  * 崩溃级别 
  * @param lusername 
  * @param message 
  */ 
public static void fatal(Logger logger, String lusername,String message){ 
  MDC.put("lusername", lusername); 
  logger.fatal(message);  
}

/** 
  * 错误级别 
  * @param username 
  * @param message 
  */ 
public static void error(Logger logger, String lusername,String message){ 
  MDC.put("lusername", lusername); 
  logger.error(message);  
}

/** 
  * 错误级别 
  * @param username 
  * @param message 
  */ 
public static void error(Logger logger, String lusername, Object message){ 
  MDC.put("lusername", lusername); 
  logger.error(message);  
}

/** 
  * 消息级别 
  * @param logger 
  * @param username 
  * @param message 
  */ 
public static void info(Logger logger, String lusername,String message){ 
  MDC.put("lusername", lusername); 
  logger.info(message);  
}

/** 
  * 警告级别 
  * @param username 
  * @param message 
  */ 
public static void warn(Logger logger, String lusername,String message){ 
  MDC.put("lusername", lusername); 
  logger.warn(message);  
}

/** 
  * 调试级别 
  * @param username 
  * @param message 
  */ 
public static void debug(Logger logger, String lusername,String message){ 
  MDC.put("lusername", lusername); 
  logger.debug(message);  

}

4、客户端调用源码 
public class test{ 
private static Logger logger = Logger.getLogger(test.class);

public static void main(String[] args) { 
LogUtil.info(logger, "wyw", "看看是否写入了数据库");


}

log4j学习日记-写入数据库的更多相关文章

  1. 怎样借助log4j把日志写入数据库中

            log4j是一个优秀的开源日志记录项目.我们不仅能够对输出的日志的格式自定义,还能够自定义日志输出的目的地,比方:屏幕.文本文件,数据 库,甚至能通过socket输出.本节使用MySQ ...

  2. 使用log4j将日志写入数据库并发送邮件

    参考: 快速了解Log4J 1.log4j的初始配置 参考该问的配置即可完整的实现写入数据库及发送邮件的功能 a.写入数据库需要配置相应的jar包,数据库类型不同,请使用指定的数据库配置,该文仅限于o ...

  3. 用log4j将日志写入数据库

    以下为log4j中的配置参数: %m 输出代码中指定的消息 %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL %r 输出自应用启动到输出该log信息耗费的毫秒数 %t 输出产 ...

  4. 使用log4j让日志写入数据库

    之前做的一个项目有这么个要求,在日志管理系统里,需要将某些日志信息存储到数据库里,供用户.管理员查看分析.因此我就花了点时间搞了一下这一功能,各位请看. 摘要:我们知道log4j能提供强大的可配置的记 ...

  5. Log4j写入数据库详解

    log4j是一个优秀的开源日志记录项目,我们不仅可以对输出的日志的格式自定义,还可以自己定义日志输出的目的地,比如:屏幕,文本文件,数据库,甚至能通过socket输出.本节主要讲述如何将日志信息输入到 ...

  6. (OAF)jdeveloper集成log4j并将日志输出到指定文件并写入数据库

    参考: How to configure Log4j in JDev 11g Ever wanted to use log4j in your adf project ? Well though Or ...

  7. Log4j(一):Log4j将日志信息写入数据库

    前言 为了监听一些数据的采集等功能,需要随时监听设备的状态,所以需要运行的时候将日志打入到数据库中. 正文 第一步: 首先是jar包,由于我使用的是springboot,所以,在springboot- ...

  8. flume学习(三):flume将log4j日志数据写入到hdfs(转)

    原文链接:flume学习(三):flume将log4j日志数据写入到hdfs 在第一篇文章中我们是将log4j的日志输出到了agent的日志文件当中.配置文件如下: tier1.sources=sou ...

  9. log4j日志写入数据库

    # log4j写入数据库 ### 前言-----------------------------log4j是写入日志到控制台和文件很常见,但是写入到数据库不多见.做性能测试写入到数据库,统计方便些. ...

随机推荐

  1. WTL 自绘 进度条Progressbar

    WTL 绘制的进度条,逻辑清晰明了,代码函数清晰易懂:基本思路就是 首先绘制 进度条背景图,然后根据动态进度不断重绘前景进度条,绘制操作在OnPaint函数里画.该类可以直接用于项目中. 使用示例: ...

  2. jQuery 分页插件 jqPagination的使用

    jqPagination 是一个简单易用的轻量级 jQuery分页插件,其使用了 HTML5 和 CSS3 技术来实现.此插件提供了几个参数设置选项,通过简单的配置即可生成分页控件.此外,它的外观样式 ...

  3. sqlite 获取数据库中的所有表

    SELECT name from sqlite_master where type='table'

  4. 微信45028错误,微信has no masssend quota hint错误

    微信45028,微信has no masssend quota hint 微信测试账号群发出现45028,has no masssend quota hint错误 >>>>&g ...

  5. JSON 学习总结 <一>:什么是JSON

    JSON的相关资料和博客很多,JSON无处不用,最近项目中一直要用到JSON,今天没有加班,就写下,算是对自己的总结,对JSON又一次深入的认识. 废话不多了,直接进入今天的主题: 如题:今天就介绍下 ...

  6. 数字证书简介及Java编码实现

    1.数字证书简介 数字证书具备常规加密解密必要的信息,包含签名算法,可用于网络数据加密解密交互,标识网络用户(计算机)身份.数字证书为发布公钥提供了一种简便的途径,其数字证书则成为加密算法以及公钥的载 ...

  7. BI任务列表

    了解点击流系统和pv/uv的相关计算 关于pv的那些事!! ···············································2014-09-10 homework做了些什 ...

  8. 30、ADO.NET、事务、DataSet

    ADO.NET ADO.NET是一组用于和数据源进行交互的面向对象类库.通常数据源是数据库,但也可以是文本文件.Excel表格.XML文件. 说白了就是使用.net操作数据库的一套类库. ADO.NE ...

  9. 在VS中关于MySQL的相关问题

    最近在vs上折腾mysql数据库 遇到了一些小问题,这里记录一下 问题一:数据源选择中没有mysql数据库的选项 解放方法: 1.安装MySql的VS插件(版本请下载最新版)mysql-for-vis ...

  10. 浅析Activity不可见与透明

    http://blog.csdn.net/lincyang/article/details/6868582 看见标题也许你会有疑问,不可见和透明不是一个意思吗? 从字面上看,这还真是差不多.但在Act ...