| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.apache.log4j.AppenderSkeleton
org.apache.log4j.jdbc.JDBCAppender
public class JDBCAppender
WARNING: This version of JDBCAppender is very likely to be completely replaced in the future. Moreoever, it does not log exceptions. The JDBCAppender provides for sending log events to a database.
Each append call adds to an ArrayList buffer.  When
  the buffer is filled each log event is placed in a sql statement
  (configurable) and executed.
  BufferSize, db URL, User, & Password are
  configurable options in the standard log4j ways.
  
The setSql(String sql) sets the SQL statement to be
  used for logging -- this statement is sent to a
  PatternLayout (either created automaticly by the
  appender or added by the user).  Therefore by default all the
  conversion patterns in PatternLayout can be used
  inside of the statement.  (see the test cases for examples)
  
Overriding the getLogStatement(org.apache.log4j.spi.LoggingEvent) method allows more
  explicit control of the statement used for logging.
  
For use as a base class:
getConnection() to pass any connection
    you want.  Typically this is used to enable application wide
    connection pooling.
     closeConnection(Connection con) -- if
     you override getConnection make sure to implement
     closeConnection to handle the connection you
     generated.  Typically this would return the connection to the
     pool it came from.
     getLogStatement(LoggingEvent event) to
     produce specialized or dynamic statements. The default uses the
     sql option value.
    
| Field Summary | |
|---|---|
| protected  java.util.ArrayList | bufferArrayList holding the buffer of Logging Events. | 
| protected  int | bufferSizesize of LoggingEvent buffer before writting to the database. | 
| protected  java.sql.Connection | connectionConnection used by default. | 
| protected  java.lang.String | databasePasswordUser to use for default connection handling | 
| protected  java.lang.String | databaseURLURL of the DB for default connection handling | 
| protected  java.lang.String | databaseUserUser to connect as for default connection handling | 
| protected  java.util.ArrayList | removesHelper object for clearing out the buffer | 
| protected  java.lang.String | sqlStatementStores the string given to the pattern layout for conversion into a SQL statement, eg: insert into LogTable (Thread, Class, Message) values ("%t", "%c", "%m"). | 
| Fields inherited from class org.apache.log4j.AppenderSkeleton | 
|---|
| closed, errorHandler, headFilter, layout, name, tailFilter, threshold | 
| Constructor Summary | |
|---|---|
| JDBCAppender() | |
| Method Summary | |
|---|---|
|  void | append(LoggingEvent event)Adds the event to the buffer. | 
|  void | close()Closes the appender, flushing the buffer first then closing the default connection if it is open. | 
| protected  void | closeConnection(java.sql.Connection con)Override this to return the connection to a pool, or to clean up the resource. | 
| protected  void | execute(java.lang.String sql)Override this to provide an alertnate method of getting connections (such as caching). | 
|  void | finalize()closes the appender before disposal | 
|  void | flushBuffer()loops through the buffer of LoggingEvents, gets a sql string from getLogStatement() and sends it to execute(). | 
|  int | getBufferSize() | 
| protected  java.sql.Connection | getConnection()Override this to link with your connection pooling system. | 
| protected  java.lang.String | getLogStatement(LoggingEvent event)By default getLogStatement sends the event to the required Layout object. | 
|  java.lang.String | getPassword() | 
|  java.lang.String | getSql()Returns pre-formated statement eg: insert into LogTable (msg) values ("%m") | 
|  java.lang.String | getURL() | 
|  java.lang.String | getUser() | 
|  boolean | requiresLayout()JDBCAppender requires a layout. | 
|  void | setBufferSize(int newBufferSize) | 
|  void | setDriver(java.lang.String driverClass)Ensures that the given driver class has been loaded for sql connection creation. | 
|  void | setPassword(java.lang.String password) | 
|  void | setSql(java.lang.String s) | 
|  void | setURL(java.lang.String url) | 
|  void | setUser(java.lang.String user) | 
| Methods inherited from class org.apache.log4j.AppenderSkeleton | 
|---|
| activateOptions, addFilter, clearFilters, doAppend, getErrorHandler, getFilter, getFirstFilter, getLayout, getName, getThreshold, isAsSevereAsThreshold, setErrorHandler, setLayout, setName, setThreshold | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Methods inherited from interface org.apache.log4j.Appender | 
|---|
| addFilter, clearFilters, doAppend, getErrorHandler, getFilter, getLayout, getName, setErrorHandler, setLayout, setName | 
| Field Detail | 
|---|
protected java.lang.String databaseURL
protected java.lang.String databaseUser
protected java.lang.String databasePassword
protected java.sql.Connection connection
getConnection and
 closeConnection methods.
protected java.lang.String sqlStatement
protected int bufferSize
protected java.util.ArrayList buffer
protected java.util.ArrayList removes
| Constructor Detail | 
|---|
public JDBCAppender()
| Method Detail | 
|---|
public void append(LoggingEvent event)
append in class AppenderSkeletonprotected java.lang.String getLogStatement(LoggingEvent event)
protected void execute(java.lang.String sql)
                throws java.sql.SQLException
java.sql.SQLExceptionprotected void closeConnection(java.sql.Connection con)
protected java.sql.Connection getConnection()
                                     throws java.sql.SQLException
java.sql.SQLExceptionpublic void close()
close in interface Appenderpublic void flushBuffer()
public void finalize()
finalize in class AppenderSkeletonpublic boolean requiresLayout()
requiresLayout in interface Appenderpublic void setSql(java.lang.String s)
public java.lang.String getSql()
public void setUser(java.lang.String user)
public void setURL(java.lang.String url)
public void setPassword(java.lang.String password)
public void setBufferSize(int newBufferSize)
public java.lang.String getUser()
public java.lang.String getURL()
public java.lang.String getPassword()
public int getBufferSize()
public void setDriver(java.lang.String driverClass)
| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||