LOG4J使用Hibernate管理数据库连接

4 篇文章 0 订阅

LOG4J向数据库中写LOG,而JDBCAppender就得要单独进立数据库连接,而写LOG的操作非常频繁,这样,如果按JDBCAppender的方法要频繁地进行连接断开数据库操作,显然,这不是最理想的。在网上有文章介绍把这个改成数据库连接池的。Hibernate现在在J2EE项目中已经应用相当广泛,下面介绍如何扩展JDBCAppender,用Hibernate的数据库连接。

查看JDBCAppender,我们可以看出,只要重载下面三个方法即可:

protected Connection getConnection() throws SQLException ;

protected void execute(String sql) throws SQLException;

protected void closeConnection(Connection con);

具体实现原码如下所示:

package com.common.util;

import java.sql.Connection;

import java.sql.SQLException;

import org.apache.log4j.spi.ErrorCode;
import org.apache.log4j.spi.LoggingEvent;

public class JDBCConnAppender extends org.apache.log4j.jdbc.JDBCAppender {

/**
  * Override 此函数来返回一个hibernate的连接。
  */

 protected Connection getConnection() throws SQLException {
  return HibernateUtil.currentSession().connection();

}

/**

*执行数据库操作。

*/

protected void execute(String sql) throws SQLException {

  Connection con = null;

  Statement stmt = null;

  try {

   con = getConnection();

   stmt = con.createStatement();

   stmt.execute(sql);
   con.commit();

  } catch (SQLException e) {

   if (stmt != null)

    stmt.close();

   throw e;

  }

  stmt.close();

  closeConnection(con);

 }

/**

*关闭数据库连接。

*/

protected void closeConnection(Connection con) {

  try {

   if (connection != null && !connection.isClosed())

    connection.close();

  } catch (SQLException e) {

   errorHandler.error("Error closing connection", e,

   ErrorCode.GENERIC_FAILURE);

  }

 }

}

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值